我需要一些帮助。我有这个xml文档:
<?xml version="1.0" encoding="utf-8"?>
<MyItems>
<Parent upc="A00000000000000000000001" sku="" archivo="pantalon1.jpg">
<Child upc="101" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
<Child upc="102" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
</Parent>
<Parent upc="A00000000000000000000002" sku="" archivo="image##.jpg">
<Child upc="101" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
<Child upc="102" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
</Parent>
<Parent upc="200" sku="" archivo="image##.jpg">
<Child upc="201" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
<Child upc="202" sku="" archivo="image##.jpg">
<GrandChild archivo="image##.jpg" />
</Child>
</Parent>
</MyItems>
然后,我试图选择“孩子”满足条件的所有“父母”。例如,所有父母都包含一个孩子,其中,子属性upc等于101
我正在研究这篇文章: Select nodes based on properties of descendant nodes
但我无法得到我想要的东西。
谢谢,祝你有愉快的一天!
答案 0 :(得分:9)
XDocument doc = ...;
var targetUpc = 101;
var query = doc.Descendants("Parent")
.Where(p => p.Elements("Child")
.Any(c => (int)c.Attribute("upc") == targetUpc)
);
所以查询的作用是选择名为Parent
的所有后代元素,其中任何名为Child
的子元素都具有名为upc
的属性,该属性等于目标upc值{{ {1}}。希望你能够遵循这一点。
答案 1 :(得分:1)
使用嵌套Where
的{{1}}。
Any
答案 2 :(得分:1)
试试这个:
string xml = @"<?xml version=""1.0"" encoding=""utf-8""?>
<MyItems>
<Parent upc=""A00000000000000000000001"" sku="""" archivo=""pantalon1.jpg"">
<Child upc=""101"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
<Child upc=""102"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
</Parent>
<Parent upc=""A00000000000000000000002"" sku="""" archivo=""image##.jpg"">
<Child upc=""101"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
<Child upc=""102"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
</Parent>
<Parent upc=""200"" sku="""" archivo=""image##.jpg"">
<Child upc=""201"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
<Child upc=""202"" sku="""" archivo=""image##.jpg"">
<GrandChild archivo=""image##.jpg"" />
</Child>
</Parent>
</MyItems>";
XElement MyItems = XElement.Parse(xml);
var parents = MyItems.Elements("Parent").Where(parent => parent.Elements("Child").Any(child => child.Attribute("upc").Value == "101"));
foreach (var parent in parents)
Console.WriteLine(parent.Attribute("upc").Value);
答案 3 :(得分:1)
这对我很有用:
var query =
from p in XDocument.Parse(xml).Root.Elements("Parent")
where (
from c in p.Elements("Child")
where c.Attribute("upc").Value == "101"
select c
).Any()
select p;