関数型構築 (LINQ to XML)

LINQ to XML には、関数型構築と呼ばれる強力な XML 要素作成機能があります。関数型構築は、単一のステートメントで XML ツリーを作成するための機能です。  

LINQ to XML プログラミング インターフェイスには、関数型構築を利用するためのいくつかの重要な機能があります。

  • XElement コンストラクターは、さまざまな種類のコンテンツ引数を受け取ります。たとえば、このコンストラクターに、子要素になる別の XElement オブジェクトや、要素の属性になる XAttribute オブジェクトを渡すことができます。また、文字列に変換され、要素のテキスト コンテンツになる他の任意の種類のオブジェクトを渡すこともできます。

  • XElement コンストラクターは、Object 型の params 配列を受け取ります。そのため、任意の数のオブジェクトを配列に渡すことができます。これにより、複雑なコンテンツを持つ要素を作成できます。

  • オブジェクトが IEnumerable<T> を実装している場合、オブジェクト内のコレクションが列挙され、コレクション内のすべての項目が追加されます。コレクションに XElement オブジェクトまたは XAttribute オブジェクトが含まれている場合、コレクション内の各項目が個別に追加されます。これは重要な機能といえます。その理由は、この機能により、LINQ クエリの結果をコンストラクターに渡すことができるためです。

これらの機能により、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")
            )
        )
    );

また、これらの機能により、XML ツリーを作成するときに、LINQ クエリの結果を使用するコードを記述することができます。次に例を示します。

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);

Visual Basic で同様の処理を行うには、XML リテラルを使用します。

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 CInt(el) > 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 ツリーの作成