考虑像xml:
<Main>
<ActivityOne>
<!-- this should be counted -->
<TaskA>yes</TaskA>
<TaskB>do do do</TaskB>
</ActivityOne>
<ActivityTwo>
<ActivityFive>
<TaskA>da da da</TaskA>
</ActivityFive>
</ActivityTwo>
<ActivityOne>
<!-- this should not be counted -->
<TaskC>yadda yadda</TaskC>
</ActivityOne>
<ActivityThree>
<ActivityOne>
<!-- this should be counted -->
<ActivityFour>
<TaskA>yes</TaskA>
</ActivityFour>
<TaskC>nope</TaskC>
</ActivityOne>
<ActivityTwo>
<TaskF>no</TaskF>
</ActivityTwo>
</ActivityThree>
<ActivityFour>
<TaskA>nope</TaskA>
</ActivityFour>
</Main>
我正在尝试计算包含一个或多个“TaskA”元素的“ActivityOne”元素的数量。
我试过了:
int count = xDoc.Descendants("ActivityOne").Where(x => x.Descendants("TaskA").Count() > 0).Count();
但它似乎只计算具有比直接子项更深的TaskA的ActivityOne元素。
答案 0 :(得分:1)
您提供的解决方案非常好:
int count = xDoc.Descendants("ActivityOne")
.Where(x => x.Descendants("TaskA").Count() > 0)
.Count();
我想添加一个可以帮助您使用XPath解决此问题的解决方案:
int count = xDoc.XPathSelectElements("//ActivityOne[descendant::TaskA]").Count();
这是一个更短的表达,在我看来,如果你需要使用特殊条件从XML中选择一些元素,这是一个更好的方法。