XContainer.Descendants XContainer.Descendants XContainer.Descendants XContainer.Descendants Method

定義

このドキュメントまたは要素の子孫要素のコレクションをドキュメント順に返します。Returns a collection of the descendant elements for this document or element, in document order.

オーバーロード

Descendants() Descendants() Descendants() Descendants()

このドキュメントまたは要素の子孫要素のコレクションをドキュメント順に返します。Returns a collection of the descendant elements for this document or element, in document order.

Descendants(XName) Descendants(XName) Descendants(XName) Descendants(XName)

このドキュメントまたは要素の子孫要素のフィルター処理されたコレクションをドキュメント順に返します。Returns a filtered collection of the descendant elements for this document or element, in document order. 一致する XName を持つ要素のみがコレクションに含められます。Only elements that have a matching XName are included in the collection.

注釈

このメソッドは遅延実行を使用します。This method uses deferred execution.

Descendants() Descendants() Descendants() Descendants()

このドキュメントまたは要素の子孫要素のコレクションをドキュメント順に返します。Returns a collection of the descendant elements for this document or element, in document order.

public:
 System::Collections::Generic::IEnumerable<System::Xml::Linq::XElement ^> ^ Descendants();
public System.Collections.Generic.IEnumerable<System.Xml.Linq.XElement> Descendants ();
member this.Descendants : unit -> seq<System.Xml.Linq.XElement>
Public Function Descendants () As IEnumerable(Of XElement)

戻り値

IEnumerable<T> の子孫要素を格納している XElementXContainerAn IEnumerable<T> of XElement containing the descendant elements of the XContainer.

次の例では、XML ツリーを作成し、この軸メソッドを使用して子孫を取得します。The following example creates an XML tree, and then uses this axis method to retrieve the descendants.

XElement xmlTree = new XElement("Root",  
    new XAttribute("Att1", "AttributeContent"),  
    new XElement("Child",  
        new XText("Some text"),  
        new XElement("GrandChild", "element content")  
    )  
);  
IEnumerable<XElement> de =  
    from el in xmlTree.Descendants()  
    select el;  
foreach (XElement el in de)  
    Console.WriteLine(el.Name);  
' Attributes are not nodes, so will not be returned by DescendantNodes.  
Dim xmlTree As XElement = _  
    <Root Att1="AttributeContent">  
        <Child>Some text  
            <GrandChild>element content</GrandChild>  
        </Child>  
    </Root>  
Dim de = From el In xmlTree.Descendants _  
         Select el  
  
For Each el In de  
    Console.WriteLine(el.Name)  
Next  

この例を実行すると、次の出力が生成されます。This example produces the following output:

Child  
GrandChild  

注釈

このメソッドは、結果IEnumerable<T>のではそれ自体を返さないことに注意してください。Note that this method will not return itself in the resulting IEnumerable<T>. DescendantsAndSelf 現在XElementのを結果に含める必要があるかどうかを確認します。See DescendantsAndSelf if you need to include the current XElement in the results.

このメソッドは遅延実行を使用します。This method uses deferred execution.

こちらもご覧ください

Descendants(XName) Descendants(XName) Descendants(XName) Descendants(XName)

このドキュメントまたは要素の子孫要素のフィルター処理されたコレクションをドキュメント順に返します。Returns a filtered collection of the descendant elements for this document or element, in document order. 一致する XName を持つ要素のみがコレクションに含められます。Only elements that have a matching XName are included in the collection.

public:
 System::Collections::Generic::IEnumerable<System::Xml::Linq::XElement ^> ^ Descendants(System::Xml::Linq::XName ^ name);
public System.Collections.Generic.IEnumerable<System.Xml.Linq.XElement> Descendants (System.Xml.Linq.XName name);
member this.Descendants : System.Xml.Linq.XName -> seq<System.Xml.Linq.XElement>
Public Function Descendants (name As XName) As IEnumerable(Of XElement)

パラメーター

name
XName XName XName XName

照合する対象の XNameThe XName to match.

戻り値

指定した IEnumerable<T> に一致する XElement の子孫要素を格納している XContainerXNameAn IEnumerable<T> of XElement containing the descendant elements of the XContainer that match the specified XName.

次の例では、要素のすべての子孫を出力します。The following example prints all descendants of an element.

// Attributes are not nodes, so will not be returned by DescendantNodes.  
XElement xmlTree = new XElement("Root",  
    new XAttribute("Att1", "AttributeContent"),  
    new XElement("Child",  
        new XText("Some text"),  
        new XElement("GrandChild", "element content")  
    )  
);  
IEnumerable<XElement> de =  
    from el in xmlTree.Descendants("Child")  
    select el;  
foreach (XElement el in de)  
    Console.WriteLine(el.Name);  
' Attributes are not nodes, so will not be returned by the descendants axis.  
Dim xmlTree As XElement = _   
    <Root Att1="AttributeContent">  
         <Child>Some text  
             <GrandChild>element content</GrandChild>  
         </Child>  
     </Root>  
  
Dim de = From el In xmlTree...<Child> _  
         Select el  
  
For Each el In de  
    Console.WriteLine(el.Name)  
Next  

この例を実行すると、次の出力が生成されます。This example produces the following output:

Child  

次の例は同じですが、この場合は XML が名前空間に含まれています。The following is the same example, but in this case the XML is in a namespace. 詳細については、「 XML 名前空間の操作」を参照してください。For more information, see Working with XML Namespaces.

// Attributes are not nodes, so will not be returned by DescendantNodes.  
XNamespace aw = "http://www.adventure-works.com";  
XElement xmlTree = new XElement(aw + "Root",  
    new XAttribute(aw + "Att1", "AttributeContent"),  
    new XElement(aw + "Child",  
        new XText("Some text"),  
        new XElement(aw + "GrandChild", "element content")  
    )  
);  
IEnumerable<XElement> de =  
    from el in xmlTree.Descendants(aw + "Child")  
    select el;  
foreach (XElement el in de)  
    Console.WriteLine(el.Name);  
Imports <xmlns:aw = "http://www.adventure-works.com">  
  
Module Module1  
    Sub Main()  
        ' Attributes are not nodes, so will not be returned by the descendants axis.  
        Dim xmlTree As XElement = _   
            <aw:Root aw:Att1="AttributeContent">  
                 <aw:Child>Some text  
                     <aw:GrandChild>element content</aw:GrandChild>  
                 </aw:Child>  
             </aw:Root>  
  
        Dim de = From el In xmlTree...<aw:Child> _  
                 Select el  
  
        For Each el In de  
            Console.WriteLine(el.Name)  
        Next  
    End Sub  
End Module  

この例を実行すると、次の出力が生成されます。This example produces the following output:

{http://www.adventure-works.com}Child  

注釈

このメソッドは遅延実行を使用します。This method uses deferred execution.

こちらもご覧ください

適用対象