使用LINQ to XML匹配更深层次的后代元素
本文关键字:深层次 后代 元素 LINQ to XML 使用 | 更新日期: 2023-09-27 17:50:05
假设我有以下XML文件:
<?xml version="1.0" encoding="UTF-8"?>
<response>
<project>
<ixGroup>105</ixGroup>
<sGroup>Place Group</sGroup>
</project>
<project>
...
我使用以下代码从中提取不同的<ixGroup>
和<sGroup>
文本值:
XDocument doc = XDocument.Load(@"C:'temp'xmlParse2.xml");
var projects = (from project in doc.Descendants("project")
select new {
id = project.Element("ixGroup").Value,
name = project.Element("sGroup").Value
}).Distinct();
foreach(var project in projects)
{
project.id.Dump("id");
project.name.Dump("name");
}
如果相同的xml文件有一个额外的元素,如<projects>
下面添加的一个:
<response>
<projects>
<project>
<ixGroup>105</ixGroup>
<sGroup>Place Group</sGroup>
</project>
<project>
...
我如何修改上面的LINQ代码来仍然访问<project>
元素?
你不必这么做。我刚刚测试了它,你当前的LINQ语句仍然会返回所有的<project>
元素,不管它们是否嵌套在<projects>
元素内。
您根本不需要修改代码。Descendants
方法将在树中搜索尽可能远的地方,以便找到匹配的元素,这既可能是诅咒,也可能是祝福。在您的示例中,即使添加了中间<projects>
节点,所编写的代码也将继续工作。
(只搜索直接子方法的方法是Children()
。
Elements只搜索子节点,而Descendants则一路向下搜索树。换句话说,您不需要做任何事情。