我想从XML文件中提取信息到使用LINQ to XML的对象中。尽管我可以返回文档和部分Id属性,但我无法访问每个部分元素的Items,它将返回文档中所有项目的IEnumerable。我知道这是正确的,因为我打电话给后裔,但我努力让它只返回每个部分元素的子项。任何人都可以帮忙吗?LINQ to XML选择子元素
XML文档
<root>
<document id="1">
<section id="1.1">
<item id="1.1.1"></item>
<item id="1.1.2"></item>
<item id="1.1.3"></item>
</section>
<section id="1.2">
<item id="1.2.1"></item>
<item id="1.2.2"></item>
</section>
</document>
</root>
LINQ查询
XElement documentRoot = XElement.Load("document.xml");
var documents = (from docs in documentRoot.Descendants("document")
select new
{
Id = (string) docs.Attribute("id"),
Sections = docs.Elements("section"),
Items = docs.Elements("section").Elements("item")
}).ToList();
foreach(var doc in documents)
{
foreach(var section in doc.Sections)
{
Console.WriteLine("SectionId: " + section.Attribute("Id"));
foreach(var item in doc.Items)
{
Console.WriteLine("ItemId: " + section.Attribute("Id"));
}
}
}
我对目标有点不清楚。您的匿名对象由文档ID,文档中的所有部分以及文档所有部分中的所有项目组成。如果您试图将XML层次结构重建为匿名对象,那么您将需要多个查询。为什么不在这种情况下使用XML? – womp 2010-01-18 23:01:50