问候。
我正在寻找一种使用 ASP.NET (C#) 解析特定目录中的多个 XML 文件的方法。我希望能够从特定元素返回内容,但在此之前,需要找到元素之间具有特定值的内容。
XML 文件示例 1:
<file>
<title>Title 1</title>
<someContent>Content</someContent>
<filter>filter</filter>
</file>
XML 文件示例 2:
<file>
<title>Title 2</title>
<someContent>Content</someContent>
<filter>filter, different filter</filter>
</file>
示例案例1:
给我所有具有“filter”过滤器的 XML。
示例案例2:
给我所有标题为“Title 1”的 XML。
看起来,这似乎可以通过 LINQ 实现,但我只看到了有关如何在有一个 XML 文件时执行此操作的示例,而不是在有多个 XML 文件时(例如在本例中)。
我希望这在服务器端完成,以便我可以在该端进行缓存。
可以使用任何版本的 .NET Framework 的功能。
Thanks!
~James
如果您使用 .Net 3.5,则使用 LINQ 这非常简单:
//get the files
XElement xe1 = XElement.Load(string_file_path_1);
XElement xe2 = XElement.Load(string_file_path_2);
//Give me all XML that has a filter of 'filter'.
var filter_elements1 = from p in xe1.Descendants("filter") select p;
var filter_elements2 = from p in xe2.Descendants("filter") select p;
var filter_elements = filter_elements1.Union(filter_elements2);
//Give me all XML that has a title of 'Title 1'.
var title1 = from p in xe1.Descendants("title") where p.Value.Equals("Title 1") select p;
var title2 = from p in xe2.Descendants("title") where p.Value.Equals("Title 1") select p;
var titles = title1.Union(title2);
这些都可以用简写形式写出来,总共只需 4 行即可得到结果:
XElement xe1 = XElement.Load(string_file_path_1);
XElement xe2 = XElement.Load(string_file_path_2);
var _filter_elements = (from p1 in xe1.Descendants("filter") select p1).Union(from p2 in xe2.Descendants("filter") select p2);
var _titles = (from p1 in xe1.Descendants("title") where p1.Value.Equals("Title 1") select p1).Union(from p2 in xe2.Descendants("title") where p2.Value.Equals("Title 1") select p2);
这些都是 IEnumerable 列表,因此它们非常容易使用:
foreach (var v in filter_elements)
Response.Write("value of filter element" + v.Value + "<br />");
LINQ 规则!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)