使用 ASP.NET (C#) 解析多个 XML 文件并返回具有特定元素的文件

2024-03-19

问候。

我正在寻找一种使用 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(使用前将#替换为@)

使用 ASP.NET (C#) 解析多个 XML 文件并返回具有特定元素的文件 的相关文章

随机推荐