如何計算中間值 (LINQ to XML)
本文說明如何計算中間值,以在 C# 和 Visual Basic 中用於排序、篩選和選取。
範例:使用 let
子句根據元素資料進行計算
下列範例會使用 let
子句來計算元素的數值乘積。 此範例會使用 XML 文件的範例 XML 檔案:數值資料。
XElement root = XElement.Load("Data.xml");
IEnumerable<decimal> extensions =
from el in root.Elements("Data")
let extension = (decimal)el.Element("Quantity") * (decimal)el.Element("Price")
where extension >= 25
orderby extension
select extension;
foreach (decimal ex in extensions)
Console.WriteLine(ex);
Dim root As XElement = XElement.Load("Data.xml")
Dim extensions As IEnumerable(Of Decimal) = _
From el In root.<Data> _
Let extension = CDec(el.<Quantity>.Value) * CDec(el.<Price>.Value) _
Where extension > 25 _
Order By extension _
Select extension
For Each ex As Decimal In extensions
Console.WriteLine(ex)
Next
這個範例會產生下列輸出:
55.92
73.50
89.99
198.00
435.00
範例:從位於命名空間的 XML 進行計算
下列範例顯示與之前相同的查詢,但針對位於命名空間的 XML。 此範例會使用 XML 文件:範例 XML 檔案:命名空間中的數值資料。
如需詳細資訊,請參閱命名空間概觀。
XElement root = XElement.Load("DataInNamespace.xml");
XNamespace ad = "http://www.adatum.com";
IEnumerable<decimal> extensions =
from el in root.Elements(ad + "Data")
let extension = (decimal)el.Element(ad + "Quantity") * (decimal)el.Element(ad + "Price")
where extension >= 25
orderby extension
select extension;
foreach (decimal ex in extensions)
Console.WriteLine(ex);
Imports <xmlns="http://www.adatum.com">
Module Module1
Sub Main()
Dim root As XElement = XElement.Load("DataInNamespace.xml")
Dim extensions As IEnumerable(Of Decimal) = _
From el In root.<Data> _
Let extension = CDec(el.<Quantity>.Value) * CDec(el.<Price>.Value) _
Where extension > 25 _
Order By extension _
Select extension
For Each ex As Decimal In extensions
Console.WriteLine(ex)
Next
End Sub
End Module
這個範例會產生下列輸出:
55.92
73.50
89.99
198.00
435.00