簡體   English   中英

LINQ:C#中XML節點的總和

[英]LINQ: Sum values of XML nodes in C#

我有一個XML文檔,我想總結一個特定名稱的所有元素。 我該怎么做呢?

您可以從以下代碼開始,該代碼對文檔中任何位置的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));

這些示例假定值以文本形式存儲在元素內,並且它是整數。

假設這是您的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);
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM