Поделиться через


Извлечение XML-данных с помощью XPathNavigator

В платформе Microsoft .NET Framework есть несколько способов представления XML-документа. К ним относится использование класса String, XmlReader, XmlWriter, XmlDocument или XPathDocument. Чтобы ускорить перемещение между различными представлениями XML-документа, в классе XPathNavigator предусмотрено несколько методов и свойств для извлечения XML как объекта String, XmlReader или XmlWriter.

Преобразование XPathNavigator в строку

Свойство OuterXml класса XPathNavigator используется для получения разметки всего XML-документа или просто разметки одного узла и его дочерних узлов.

ПримечаниеПримечание

Свойство InnerXml получает разметку или просто дочерние узлы данного узла.

В следующем примере кода показано, как сохранить целый XML-документ, содержащийся в объекте XPathNavigator как String, а также один узел и его дочерние узлы.

Dim document As XPathDocument = New XPathDocument("input.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

' Save the entire input.xml document to a string.
Dim xml As String = navigator.OuterXml

' Now save the Root element and its child nodes to a string.
navigator.MoveToChild(XPathNodeType.Element)
Dim root As String = navigator.OuterXml
XPathDocument document = new XPathDocument("input.xml");
XPathNavigator navigator = document.CreateNavigator();

// Save the entire input.xml document to a string.
string xml = navigator.OuterXml;

// Now save the Root element and its child nodes to a string.
navigator.MoveToChild(XPathNodeType.Element);
string root = navigator.OuterXml;

Преобразование XPathNavigator в XmlReader

Метод ReadSubtree используется для потоковой записи всего содержимого XML-документа или отдельного его узла с дочерними узлами в объект XmlReader.

Когда объект XmlReader создан с текущим узлом и дочерними узлами, свойство ReadState объекта XmlReader имеет значение Initial. Когда метод Read объекта XmlReader вызывается в первый раз, XmlReader перемещается в текущий узел XPathNavigator. Новый объект XmlReader продолжает считывание до тех пор, пока не будет достигнут конец XML-дерева. На этом этапе метод Read возвращает false, а свойство ReadState объекта XmlReader имеет значение EndOfFile.

Позиция объекта XPathNavigator не изменяется при создании или перемещении объекта XmlReader. Метод ReadSubtree допустим только при размещении на элементе или в корневом узле.

Следующий пример показывает, как получить объект XmlReader, содержащий весь XML-документ в объекте XPathDocument, так же как и для отдельного узла с дочерними узлами.

Dim document As XPathDocument = New XPathDocument("books.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

' Stream the entire XML document to the XmlReader.
Dim xml As XmlReader = navigator.ReadSubtree()

While xml.Read()
    Console.WriteLine(xml.ReadInnerXml())
End While

xml.Close()

' Stream the book element and its child nodes to the XmlReader.
navigator.MoveToChild("bookstore", "")
navigator.MoveToChild("book", "")

Dim book As XmlReader = navigator.ReadSubtree()

While book.Read()
    Console.WriteLine(book.ReadInnerXml())
End While

book.Close()
XPathDocument document = new XPathDocument("books.xml");
XPathNavigator navigator = document.CreateNavigator();

// Stream the entire XML document to the XmlReader.
XmlReader xml = navigator.ReadSubtree();

while (xml.Read())
{
    Console.WriteLine(xml.ReadInnerXml());
}

xml.Close();

// Stream the book element and its child nodes to the XmlReader.
navigator.MoveToChild("bookstore", "");
navigator.MoveToChild("book", "");

XmlReader book = navigator.ReadSubtree();

while (book.Read())
{
    Console.WriteLine(book.ReadInnerXml());
}

book.Close();

В примере в качестве входных данных используется файл books.xml.

<?xml version="1.0" encoding="utf-8" ?> 
<bookstore>
    <book genre="autobiography" publicationdate="1981-03-22" ISBN="1-861003-11-0">
        <title>The Autobiography of Benjamin Franklin</title>
        <author>
            <first-name>Benjamin</first-name>
            <last-name>Franklin</last-name>
        </author>
        <price>8.99</price>
    </book>
    <book genre="novel" publicationdate="1967-11-17" ISBN="0-201-63361-2">
        <title>The Confidence Man</title>
        <author>
            <first-name>Herman</first-name>
            <last-name>Melville</last-name>
        </author>
        <price>11.99</price>
    </book>
    <book genre="philosophy" publicationdate="1991-02-15" ISBN="1-861001-57-6">
        <title>The Gorgias</title>
        <author>
            <name>Plato</name>
        </author>
        <price>9.99</price>
    </book>
</bookstore>

Преобразование XPathNavigator в XmlWriter

Метод WriteSubtree используется для потоковой записи всего содержимого XML-документа или отдельного его узла с дочерними узлами в объект XmlWriter.

Позиция объекта XPathNavigator не изменяется при создании объекта XmlWriter.

Следующий пример показывает, как получить объект XmlWriter, содержащий весь XML-документ в объекте XPathDocument, так же как и для отдельного узла с дочерними узлами.

Dim document As XPathDocument = New XPathDocument("books.xml")
Dim navigator As XPathNavigator = document.CreateNavigator()

' Stream the entire XML document to the XmlWriter.
Dim xml As XmlWriter = XmlWriter.Create("newbooks.xml")
navigator.WriteSubtree(xml)
xml.Close()

' Stream the book element and its child nodes to the XmlWriter.
navigator.MoveToChild("bookstore", "")
navigator.MoveToChild("book", "")

Dim book As XmlWriter = XmlWriter.Create("book.xml")
navigator.WriteSubtree(book)
book.Close()
XPathDocument document = new XPathDocument("books.xml");
XPathNavigator navigator = document.CreateNavigator();

// Stream the entire XML document to the XmlWriter.
XmlWriter xml = XmlWriter.Create("newbooks.xml");
navigator.WriteSubtree(xml);
xml.Close();

// Stream the book element and its child nodes to the XmlWriter.
navigator.MoveToChild("bookstore", "");
navigator.MoveToChild("book", "");

XmlWriter book = XmlWriter.Create("book.xml");
navigator.WriteSubtree(book);
book.Close();

В данном примере в качестве входного файла используется указанный выше файл books.xml.

См. также

Ссылки

XmlDocument

XPathDocument

XPathNavigator

Основные понятия

Обработка XML-данных с использованием модели данных XPath

Навигация в наборе узлов с помощью XPathNavigator

Навигация по узлам атрибутов и пространств имен с помощью XPathNavigator

Доступ к XML-данным со строгой типизацией с помощью XPathNavigator