如何计算包含特定元素的特定元素?

时间:2015-12-03 15:54:03

标签: c# linq-to-xml

考虑像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元素。

1 个答案:

答案 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中选择一些元素,这是一个更好的方法。