如何解决使用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()
。
,元素仅搜索子节点,而后代则一直沿树向下移动。换句话说,您无需执行任何操作。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。