[英]C# Linq to XML, get parents when a child satisfy condition
我需要协助。 我有这个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
我正在研究这篇文章: 根据后代节点的属性选择节点
但我无法得到我想要的东西。
感谢,并有一个愉快的一天!
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值targetUpc
。 希望你能够遵循这一点。
使用嵌套Any
的Where
。
var xml = XElement.Parse(yourString);
var result = xml.Elements("Parent").Where(parent =>
parent.Elements("Child").Any(child => child.Attribute("upc").Value == "101"));
试试这个:
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);
这适合我:
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;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.