使用LINQ to XML匹配更深的后代元素?

| 假设我有以下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>
元素中。     
您根本不需要修改代码。 “ 9”方法将根据需要在树的最下方进行搜索,以找到匹配的元素,这既可以是诅咒,也可以是祝福。在您的情况下,即使您添加中间“ 4”节点,编写的代码也将继续起作用。 (仅搜索直接子方法的方法是
Children()
。     
元素仅搜索子节点,而后代则一直沿树向下移动。换句话说,您无需执行任何操作。     

要回复问题请先登录注册