使用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 to XML匹配更深层次的后代元素

你不必这么做。我刚刚测试了它,你当前的LINQ语句仍然会返回所有的<project>元素,不管它们是否嵌套在<projects>元素内。

您根本不需要修改代码。Descendants方法将在树中搜索尽可能远的地方,以便找到匹配的元素,这既可能是诅咒,也可能是祝福。在您的示例中,即使添加了中间<projects>节点,所编写的代码也将继续工作。

(只搜索直接子方法的方法是Children()

Elements只搜索子节点,而Descendants则一路向下搜索树。换句话说,您不需要做任何事情。