中間値を計算する方法 (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
関連項目
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET