다음을 통해 공유


XElement 클래스 개요

XElement 클래스는 LINQ to XML의 기본 클래스 중 하나입니다. XML 요소를 나타냅니다. 다음 목록은 이 클래스를 어떤 용도로 사용할 수 있는지 보여 줍니다.

  • 요소를 만듭니다.
  • 요소의 콘텐츠를 변경합니다.
  • 자식 요소를 추가, 변경 또는 삭제합니다.
  • 요소에 특성을 추가합니다.
  • 요소의 콘텐츠를 텍스트 형식으로 직렬화합니다.

또한 System.Xml, XmlReaderXmlWriter과 같은 XslCompiledTransform의 다른 클래스와 상호 운용할 수도 있습니다.

이 문서에서는 XElement 클래스에서 제공하는 기능을 설명합니다.

XML 트리 구문

다음을 포함하여 다양한 방법으로 XML 트리를 구성할 수 있습니다.

  • 코드에서 XML 트리를 생성할 수 있습니다. 자세한 내용은 XML 트리를 참조하세요.
  • TextReader, 텍스트 파일 또는 웹 주소(URL)와 같은 다양한 소스에서 XML의 구문을 분석할 수 있습니다. 자세한 내용은 XML 구문 분석을 참조하세요.
  • XmlReader를 사용하여 트리를 채울 수 있습니다. 자세한 내용은 ReadFrom를 참조하세요.
  • 내용을 XmlWriter에 쓸 수 있는 모듈이 있는 경우 CreateWriter 메서드를 사용하여 작성기를 만들고 모듈에 작성기를 전달한 다음 XmlWriter에 쓴 내용을 사용하여 XML 트리를 채울 수 있습니다.

다음 예에서는 트리를 만듭니다. C# 버전은 중첩된 요소 만들기를 사용합니다. Visual Basic에서도 동일한 기술을 사용할 수 있지만 이 예에서는 XML 리터럴을 사용합니다.

XElement contacts =
    new XElement("Contacts",
        new XElement("Contact",
            new XElement("Name", "Patrick Hines"),
            new XElement("Phone", "206-555-0144"),
            new XElement("Address",
                new XElement("Street1", "123 Main St"),
                new XElement("City", "Mercer Island"),
                new XElement("State", "WA"),
                new XElement("Postal", "68042")
            )
        )
    );
Dim contacts As XElement = _
    <Contacts>
        <Contact>
            <Name>Patrick Hines</Name>
            <Phone>206-555-0144</Phone>
            <Address>
                <Street1>123 Main St</Street1>
                <City>Mercer Island</City>
                <State>WA</State>
                <Postal>68042</Postal>
            </Address>
        </Contact>
    </Contacts>

다음 예와 같이 LINQ to XML 쿼리를 사용하여 XML 트리를 채울 수도 있습니다.

XElement srcTree = new XElement("Root",
    new XElement("Element", 1),
    new XElement("Element", 2),
    new XElement("Element", 3),
    new XElement("Element", 4),
    new XElement("Element", 5)
);
XElement xmlTree = new XElement("Root",
    new XElement("Child", 1),
    new XElement("Child", 2),
    from el in srcTree.Elements()
    where (int)el > 2
    select el
);
Console.WriteLine(xmlTree);
Dim srcTree As XElement = _
    <Root>
        <Element>1</Element>
        <Element>2</Element>
        <Element>3</Element>
        <Element>4</Element>
        <Element>5</Element>
    </Root>
Dim xmlTree As XElement = _
    <Root>
        <Child>1</Child>
        <Child>2</Child>
        <%= From el In srcTree.Elements() _
            Where el.Value > 2 _
            Select el %>
    </Root>
Console.WriteLine(xmlTree)

이 예제는 다음과 같은 출력을 생성합니다.

<Root>
  <Child>1</Child>
  <Child>2</Child>
  <Element>3</Element>
  <Element>4</Element>
  <Element>5</Element>
</Root>

XML 트리 직렬화

XML 트리를 File, TextWriter 또는 XmlWriter로 serialize할 수 있습니다.

자세한 내용은 XML 트리 직렬화를 참조하세요.

축 메서드를 통해 XML 데이터 검색

축 메서드를 사용하여 특성, 자식 요소, 하위 요소 및 상위 요소를 검색할 수 있습니다. LINQ to XML 쿼리는 축 메서드에 대해 작동하며 XML 트리를 탐색하고 처리하는 유연하고 강력한 몇 가지 방법을 제공합니다.

자세한 내용은 LINQ to XML 축 개요를 참조하세요.

XML 트리 쿼리

XML 트리에서 데이터를 추출하는 LINQ to XML 쿼리를 작성할 수 있습니다.

자세한 내용은 쿼리 XML 트리 개요를 참조하세요.

XML 트리 수정

콘텐츠나 특성 변경을 포함하여 다양한 방법으로 요소를 수정할 수 있습니다. 또한 부모에서 요소를 제거할 수도 있습니다.

자세한 내용은 XML 트리 수정을 참조하세요.

참고 항목