我有以下 XML 文档:
<?xml version="1.0" encoding="UTF-8"?>
<FamilyTree>
<Parent name="Ken">
<Child name="Lorna">
<Grandchild name="Andrew"/>
<Grandchild name="Brian"/>
</Child>
<Child name="Mike">
<Grandchild name="Ann"/>
<Grandchild name="Beth"/>
</Child>
</Parent>
<Parent name="Norma">
<Child name="Owen">
<Grandchild name="Charles"/>
</Child>
<Child name="Peter">
<Grandchild name="Charlotte"/>
</Child>
</Parent>
<Parent name="Quinn">
<Child name="Robert">
<Grandchild name="Debbie"/>
<Grandchild name="Eric"/>
</Child>
<Child name="Susan">
<Grandchild name="Frank"/>
</Child>
</Parent>
<Parent name="Tom">
<Child name="Ursula">
<Grandchild name="George"/>
<Grandchild name="Harriet"/>
</Child>
<Child name="Victor">
<Grandchild name="Ian"/>
<Grandchild name="Juliet"/>
</Child>
</Parent>
</FamilyTree>
我正在尝试选择拥有至少两个自己的 child (“孙子”)的 child 的所有“ parent ”。请注意,我不是在寻找至少有两个“孙子[ren]”的“ parent ”。
下面的 LINQ 查询有效,但我觉得它不是最优雅的。
IEnumerable<XElement> parents = (from c in familyTreeElement.Descendants("Child")
where c.Elements().Count() > 1
select c.Parent).Distinct();
有没有更好的方法来指定它?
最佳答案
嗯...我发现很难完全理解它:)
通常要找出是否有 any 元素,我会使用 Any
- 但你想看看是否有至少两个 元素。不过,我们仍然不需要使用 Count
- 因为至少有两个元素与跳过一个元素并查看是否还有任何元素是一样的。所以……
var parents = familyTreeElement.Elements("Parent")
.Where(parent => parent.Elements("Child").Any(
child => child.Elements("Grandchild").Skip(1).Any()));
我认为这行得通——而且实际上它读起来不太好:
对于每个 parent ,在忽略第一个(孙) child 后,查看是否有任何 child 有任何(孙) child 。
我怀疑使用 XPath(根据 Marc 的回答)是最易读的选择。
关于c# - 根据后代节点的属性选择节点的最佳 LINQ-to-XML 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/787240/