XmlNode.SelectNodes 메서드

정의

XPath 식과 일치하는 노드의 목록을 선택합니다.

오버로드

SelectNodes(String)

XPath 식과 일치하는 노드의 목록을 선택합니다.

SelectNodes(String, XmlNamespaceManager)

XPath 식과 일치하는 노드의 목록을 선택합니다. XPath 식에 있는 접두사는 제공된 XmlNamespaceManager를 사용해 확인합니다.

설명

XPath 식에 네임스페이스를 포함할 수 있습니다. 네임스페이스는 XmlNamespaceManager를 사용하여 확인할 수 있습니다. XPath 식에 접두사 및 네임스페이스 URI 쌍이 포함된 경우 접두사 및 네임스페이스 URI 쌍을 XmlNamespaceManager추가해야 합니다.

참고

XPath 식에 접두사가 포함되지 않은 경우 네임스페이스 URI가 빈 네임스페이스라고 가정합니다. XML에 기본 네임스페이스가 포함되어 있는 경우에도 접두사 및 네임스페이스 URI를 XmlNamespaceManager추가해야 합니다. 그렇지 않으면 노드가 선택되지 않습니다.

자세한 내용은 XPath 탐색을 사용하여 노드 선택을 참조하세요. 코드 예제의 경우 이전 섹션의 오버로드 목록에서 오버로드를 선택합니다.

SelectNodes(String)

XPath 식과 일치하는 노드의 목록을 선택합니다.

public:
 System::Xml::XmlNodeList ^ SelectNodes(System::String ^ xpath);
public System.Xml.XmlNodeList? SelectNodes (string xpath);
public System.Xml.XmlNodeList SelectNodes (string xpath);
member this.SelectNodes : string -> System.Xml.XmlNodeList
Public Function SelectNodes (xpath As String) As XmlNodeList

매개 변수

xpath
String

XPath 식입니다.

반환

XmlNodeList

Xpath 쿼리와 일치하는 노드의 컬렉션이 포함된 XmlNodeList입니다.

예외

XPath 식에 접두사가 포함되어 있는 경우 XPath 예제를 참조하세요.

예제

다음 예제에서는 저자의 성이 오스틴인 모든 책을 선택한 다음 해당 책의 가격을 변경합니다.

#using <System.Xml.dll>

using namespace System;
using namespace System::IO;
using namespace System::Xml;
int main()
{
   XmlDocument^ doc = gcnew XmlDocument;
   doc->Load( "booksort.xml" );
   XmlNodeList^ nodeList;
   XmlNode^ root = doc->DocumentElement;
   nodeList = root->SelectNodes( "descendant::book[author/last-name='Austen']" );
   
   //Change the price on the books.
   System::Collections::IEnumerator^ myEnum = nodeList->GetEnumerator();
   while ( myEnum->MoveNext() )
   {
      XmlNode^ book = safe_cast<XmlNode^>(myEnum->Current);
      book->LastChild->InnerText = "15.95";
   }

   Console::WriteLine( "Display the modified XML document...." );
   doc->Save( Console::Out );
}
using System;
using System.Xml;

public class Sample6
{
    public static void Main()
    {
        XmlDocument doc = new XmlDocument();
        doc.Load("booksort.xml");

        XmlNodeList nodeList;
        XmlNode root = doc.DocumentElement;

        nodeList = root.SelectNodes("descendant::book[author/last-name='Austen']");

        //Change the price on the books.
        foreach (XmlNode book in nodeList)
        {
            book.LastChild.InnerText = "15.95";
        }

        Console.WriteLine("Display the modified XML document....");
        doc.Save(Console.Out);
    }
}
Imports System.IO
Imports System.Xml

public class Sample

  public shared sub Main()

    'Create the XmlDocument.
    Dim doc as XmlDocument = new XmlDocument()
    doc.Load("booksort.xml")
           
    Dim book as XmlNode
    Dim nodeList as XmlNodeList 
    Dim root as XmlNode = doc.DocumentElement

    nodeList=root.SelectNodes("descendant::book[author/last-name='Austen']")
 
    'Change the price on the books.
    for each book in nodeList      
      book.LastChild.InnerText="15.95"
    next 

    Console.WriteLine("Display the modified XML document....")
    doc.Save(Console.Out)
    
  end sub
end class

이 예제에서는 다음 XML을 사용합니다.


<?xml version="1.0"?>
<!-- A fragment of a book store inventory database -->
<bookstore xmlns:bk="urn:samples">
  <book genre="novel" publicationdate="1997" bk:ISBN="1-861001-57-8">
    <title>Pride And Prejudice</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>24.95</price>
  </book>
  <book genre="novel" publicationdate="1992" bk:ISBN="1-861002-30-1">
    <title>The Handmaid's Tale</title>
    <author>
      <first-name>Margaret</first-name>
      <last-name>Atwood</last-name>
    </author>
    <price>29.95</price>
  </book>
  <book genre="novel" publicationdate="1991" bk:ISBN="1-861001-57-6">
    <title>Emma</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>19.95</price>
  </book>
  <book genre="novel" publicationdate="1982" bk:ISBN="1-861001-45-3">
    <title>Sense and Sensibility</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>19.95</price>
  </book>
</bookstore>

설명

XPath 식에 네임스페이스 확인이 필요한 경우 인수로 사용하는 오버로드를 XmlNamespaceManager 사용해야 SelectNodes 합니다. 네임스페이 XmlNamespaceManager 스를 확인하는 데 사용됩니다.

참고

XPath 식에 접두사가 포함되지 않은 경우 네임스페이스 URI가 빈 네임스페이스라고 가정합니다. XML에 기본 네임스페이스가 포함되어 있는 경우에도 접두사 및 네임스페이스 URI를 사용하고 XmlNamespaceManager 추가해야 합니다. 그렇지 않으면 노드가 선택되지 않습니다. 자세한 내용은 XPath 탐색을 사용하여 노드 선택을 참조하세요.

참고

XPath 식을 작성할 때 일반적인 문제는 식에 작은따옴표(') 또는 큰따옴표(")를 포함하는 방법입니다. 작은따옴표가 포함된 값을 검색해야 하는 경우 문자열을 큰따옴표로 묶어야 합니다. 큰따옴표가 포함된 값을 검색해야 하는 경우 문자열을 작은따옴표로 묶어야 합니다.

예를 들어 다음과 같은 XML이 있다고 가정합니다.

<bookstore>  
  <book>  
    <title>&apos;Emma&apos;</title>  
  </book>  
</bookstore>  

다음 Visual Basic 코드는 큰따옴표를 포함하는 요소를 선택합니다.

nodeList = root.SelectNodes("//book[contains(title,""'Emma'"")]")  

이 메서드는 DOM(문서 개체 모델)에 대한 Microsoft 확장입니다.

이 메서드에서 반환된 개체는 XmlNodeList 기본 문서가 변경되지 않은 상태로 유지되는 동안 유효합니다. 기본 문서가 변경되면 예기치 않은 결과가 반환될 수 있습니다(예외는 throw되지 않음).

추가 정보

적용 대상

SelectNodes(String, XmlNamespaceManager)

XPath 식과 일치하는 노드의 목록을 선택합니다. XPath 식에 있는 접두사는 제공된 XmlNamespaceManager를 사용해 확인합니다.

public:
 System::Xml::XmlNodeList ^ SelectNodes(System::String ^ xpath, System::Xml::XmlNamespaceManager ^ nsmgr);
public System.Xml.XmlNodeList? SelectNodes (string xpath, System.Xml.XmlNamespaceManager nsmgr);
public System.Xml.XmlNodeList SelectNodes (string xpath, System.Xml.XmlNamespaceManager nsmgr);
member this.SelectNodes : string * System.Xml.XmlNamespaceManager -> System.Xml.XmlNodeList
Public Function SelectNodes (xpath As String, nsmgr As XmlNamespaceManager) As XmlNodeList

매개 변수

xpath
String

XPath 식입니다. XPath 예제를 참조하세요.

nsmgr
XmlNamespaceManager

XPath 식의 접두사에 대한 네임스페이스를 확인하기 위해 사용할 XmlNamespaceManager입니다.

반환

XmlNodeList

Xpath 쿼리와 일치하는 노드의 컬렉션이 포함된 XmlNodeList입니다.

예외

XPath 식에 XmlNamespaceManager에서 정의되지 않은 접두사가 포함되어 있는 경우

예제

다음 예제에서는 각 ISBN 특성의 값을 표시합니다. 이 예제에서는 클래스에서 상속되는 개체를 XmlNode 사용합니다XmlElement.

#using <System.Xml.dll>

using namespace System;
using namespace System::IO;
using namespace System::Xml;
using namespace System::Collections;
int main()
{
   XmlDocument^ doc = gcnew XmlDocument;
   doc->Load( "booksort.xml" );
   
   // Create an XmlNamespaceManager for resolving namespaces.
   XmlNamespaceManager^ nsmgr = gcnew XmlNamespaceManager( doc->NameTable );
   nsmgr->AddNamespace( "bk", "urn:samples" );
   
   // Select and display the value of all the ISBN attributes.
   XmlNodeList^ nodeList;
   XmlElement^ root = doc->DocumentElement;
   nodeList = root->SelectNodes( "/bookstore/book/@bk:ISBN", nsmgr );
   IEnumerator^ myEnum = nodeList->GetEnumerator();
   while ( myEnum->MoveNext() )
   {
      XmlNode^ isbn = safe_cast<XmlNode^>(myEnum->Current);
      Console::WriteLine( isbn->Value );
   }
}
using System;
using System.IO;
using System.Xml;

public class Sample
{
  public static void Main()
  {

      XmlDocument doc = new XmlDocument();
      doc.Load("booksort.xml");

      //Create an XmlNamespaceManager for resolving namespaces.
      XmlNamespaceManager nsmgr = new XmlNamespaceManager(doc.NameTable);
      nsmgr.AddNamespace("bk", "urn:samples");

      //Select and display the value of all the ISBN attributes.
      XmlNodeList nodeList;
      XmlElement root = doc.DocumentElement;
      nodeList = root.SelectNodes("/bookstore/book/@bk:ISBN", nsmgr);
      foreach (XmlNode isbn in nodeList){
        Console.WriteLine(isbn.Value);
      }
   }
}
Imports System.IO
Imports System.Xml

public class Sample

  public shared sub Main()

      Dim doc as XmlDocument = new XmlDocument()
      doc.Load("booksort.xml")

      'Create an XmlNamespaceManager for resolving namespaces.
      Dim nsmgr as XmlNamespaceManager = new XmlNamespaceManager(doc.NameTable)
      nsmgr.AddNamespace("bk", "urn:samples")

      'Select and display the value of all the ISBN attributes.
      Dim nodeList as XmlNodeList 
      Dim root as XmlElement = doc.DocumentElement
      nodeList = root.SelectNodes("/bookstore/book/@bk:ISBN", nsmgr)
      Dim isbn as XmlNode
      for each isbn in nodeList
        Console.WriteLine(isbn.Value)
      next

  end sub
end class

이 예제에서는 파일을 booksort.xml입력으로 사용합니다.


<?xml version="1.0"?>
<!-- A fragment of a book store inventory database -->
<bookstore xmlns:bk="urn:samples">
  <book genre="novel" publicationdate="1997" bk:ISBN="1-861001-57-8">
    <title>Pride And Prejudice</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>24.95</price>
  </book>
  <book genre="novel" publicationdate="1992" bk:ISBN="1-861002-30-1">
    <title>The Handmaid's Tale</title>
    <author>
      <first-name>Margaret</first-name>
      <last-name>Atwood</last-name>
    </author>
    <price>29.95</price>
  </book>
  <book genre="novel" publicationdate="1991" bk:ISBN="1-861001-57-6">
    <title>Emma</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>19.95</price>
  </book>
  <book genre="novel" publicationdate="1982" bk:ISBN="1-861001-45-3">
    <title>Sense and Sensibility</title>
    <author>
      <first-name>Jane</first-name>
      <last-name>Austen</last-name>
    </author>
    <price>19.95</price>
  </book>
</bookstore>

설명

XPath 식에 네임스페이스를 포함할 수 있습니다. 네임스페이스는 XmlNamespaceManager를 사용하여 확인할 수 있습니다. XPath 식에 접두사가 포함된 경우 접두사 및 네임스페이스 URI 쌍을 에 추가 XmlNamespaceManager해야 합니다.

참고

XPath 식에 접두사가 포함되지 않은 경우 네임스페이스 URI가 빈 네임스페이스라고 가정합니다. XML에 기본 네임스페이스가 포함되어 있는 경우에도 접두사 및 네임스페이스 URI를 XmlNamespaceManager추가해야 합니다. 그렇지 않으면 노드가 선택되지 않습니다. 자세한 내용은 XPath 탐색을 사용하여 노드 선택을 참조하세요.

예를 들어 다음 XML이 있는 경우:

<bookstore xmlns="http://www.lucernepublishing.com">  
 <book>  
   <title>Pride And Prejudice</title>  
 </book>  
</bookstore>  

다음 C# 코드는 모든 책 노드를 선택합니다.

XmlNamespaceManager nsmgr = new XmlNamespaceManager(doc.NameTable);  
nsmgr.AddNamespace("ab", "http://www.lucernepublishing.com");  
XmlNodeList nodelist = doc.SelectNodes("//ab:book", nsmgr);  

참고

XPath 식을 작성할 때 일반적인 문제는 식에 작은따옴표(') 또는 큰따옴표(")를 포함하는 방법입니다. 작은따옴표가 포함된 값을 검색해야 하는 경우 문자열을 큰따옴표로 묶어야 합니다. 큰따옴표가 포함된 값을 검색해야 하는 경우 문자열을 작은따옴표로 묶어야 합니다.

예를 들어 다음과 같은 XML이 있다고 가정합니다.

<bookstore xmlns="http://www.lucernepublishing.com">  
  <book>  
    <title>&apos;Emma&apos;</title>  
  </book>  
</bookstore>  

다음 Visual Basic 코드는 큰따옴표를 포함하는 요소를 선택합니다.

Dim nsmgr As XmlNamespaceManager = New XmlNamespaceManager(doc.NameTable)  
nsmgr.AddNamespace("ab", "http://www.lucernepublishing.com")  
nodeList = root.SelectNodes("//ab:book[contains(ab:title,""'Emma'"")]", nsmgr)  

이 메서드는 DOM(문서 개체 모델)에 대한 Microsoft 확장입니다.

이 메서드에서 반환된 개체는 XmlNodeList 기본 문서가 변경되지 않은 상태로 유지되는 동안 유효합니다. 기본 문서가 변경되면 예기치 않은 결과가 반환될 수 있습니다(예외는 throw되지 않음).

추가 정보

적용 대상