중간 값을 계산하는 방법(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에서 찾을 수 있으며, 여기서 문제와 끌어오기 요청을 만들고 검토할 수도 있습니다. 자세한 내용은 참여자 가이드를 참조하세요.
.NET