XmlNode.SelectNodes 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
XPath 식과 일치하는 노드의 목록을 선택합니다.
오버로드
SelectNodes(String) |
XPath 식과 일치하는 노드의 목록을 선택합니다. |
SelectNodes(String, XmlNamespaceManager) |
XPath 식과 일치하는 노드의 목록을 선택합니다. XPath 식에 있는 접두사는 제공된 XmlNamespaceManager를 사용해 확인합니다. |
설명
XPath 식에 네임스페이스를 포함할 수 있습니다. 네임스페이스는 XmlNamespaceManager
를 사용하여 확인할 수 있습니다. XPath 식에 접두사를 포함하는 경우 접두사 및 네임스페이스 URI 쌍을 에 XmlNamespaceManager
추가해야 합니다.
참고
XPath 식에 접두사를 포함하지 않으면 네임스페이스 URI가 빈 네임스페이스라고 가정합니다. XML에 기본 네임스페이스가 포함된 경우 접두사 및 네임스페이스 URI를 XmlNamespaceManager
에 추가해야 합니다. 그렇지 않으면 노드가 선택되지 않습니다.
자세한 내용은 XPath 탐색을 사용하여 노드 선택을 참조하세요. 코드 예제의 경우 이전 섹션의 오버로드 목록에서 오버로드를 선택합니다.
SelectNodes(String)
- Source:
- XmlNode.cs
- Source:
- XmlNode.cs
- Source:
- XmlNode.cs
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 식입니다.
반환
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에 기본 네임스페이스가 포함된 경우에도 를 사용하고 XmlNamespaceManager
접두사 및 네임스페이스 URI를 추가해야 합니다. 그렇지 않으면 노드가 선택되지 않습니다. 자세한 내용은 XPath 탐색을 사용하여 노드 선택을 참조하세요.
참고
XPath 식을 작성할 때 일반적인 문제는 식에 작은따옴표(') 또는 큰따옴표(")를 포함하는 방법입니다. 작은따옴표를 포함하는 값을 검색해야 하는 경우 문자열을 큰따옴표로 묶어야 합니다. 큰따옴표를 포함하는 값을 검색해야 하는 경우 문자열을 작은따옴표로 묶어야 합니다.
예를 들어 다음과 같은 XML이 있다고 가정합니다.
<bookstore>
<book>
<title>'Emma'</title>
</book>
</bookstore>
다음 Visual Basic 코드는 작은따옴표를 포함하는 요소를 선택합니다.
nodeList = root.SelectNodes("//book[contains(title,""'Emma'"")]")
이 메서드는 DOM(문서 개체 모델)에 대한 Microsoft 확장입니다.
이 메서드에서 반환된 개체는 XmlNodeList 유효하지만 기본 문서는 변경되지 않습니다. 기본 문서가 변경되면 예기치 않은 결과가 반환될 수 있습니다(예외가 throw되지 않음).
추가 정보
적용 대상
SelectNodes(String, XmlNamespaceManager)
- Source:
- XmlNode.cs
- Source:
- XmlNode.cs
- Source:
- XmlNode.cs
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
매개 변수
- nsmgr
- XmlNamespaceManager
XPath 식의 접두사에 대한 네임스페이스를 확인하기 위해 사용할 XmlNamespaceManager입니다.
반환
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>'Emma'</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되지 않음).
추가 정보
적용 대상
.NET