LINQ:C#中XML节点的总和值

时间:2010-03-11 00:20:08

标签: c# xml linq

我有一个XML文档,我想总结一个特定名称的所有元素。我该怎么做?

2 个答案:

答案 0 :(得分:5)

您可以从以下代码开始,该代码对文档中任何位置的specificName元素的值进行求和(Descendants返回具有指定名称的所有元素的集合,无论它们的嵌套程度如何) :

var doc = XDocument.Load("doc.xml");
var sum = (from nd in doc.Descendants("specificName")
           select Int32.Parse(nd.Value)).Sum();

或者,如果您不想使用查询语法,可以编写如下内容:

var sum = doc.Descendants("specificName").Sum(nd => 
            Int32.Parse(nd.Value));

这些示例假定该值存储为元素内的文本,并且它是一个整数。

答案 1 :(得分:1)

假设这是您的XML:

<nodes>
     <reading c='1'>17</reading>
     <reading c='2'>18</reading>
     <reading c='3'>19</reading>
     <reading c='4'>21</reading>
     <reading c='5'>4</reading>
     <reading c='6'>3</reading>
     <reading c='7'>7</reading>
</nodes>

然后使用此代码汇总reading元素的值:

public void Run()
{
    XDocument doc = XDocument.Load(fileToLoad);
    System.Console.WriteLine("\nSumming:");
    var sum = doc.Element("nodes")
                 .Elements("reading")
                 .Sum(n => int.Parse(n.Value));

    Console.WriteLine("  {0}", sum);
}