问题描述
|
假设我有以下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()
。
,元素仅搜索子节点,而后代则一直沿树向下移动。换句话说,您无需执行任何操作。