Использование Visual C# для навигации по XML-документам с помощью класса XPathNavigator

В этой статье описывается, как перемещаться по XML-документам XPathNavigator с помощью объекта, созданного XPathDocument из объекта .

Исходная версия продукта: Visual C#
Исходный номер базы знаний: 308343

Сводка

Этот пример загружает XPathDocument объект с XML-данными, создает XPathNavigator объект в виде представления данных и отображает XML-код путем обхода документа.

В этой статье рассматриваются следующие пространства имен библиотеки классов Microsoft платформа .NET Framework:

  • System.Xml
  • System.Xml.XPath

Сведения о версии .NET для Microsoft Visual Basic см. в статье Навигация по XML с помощью класса XPathNavigator с помощью Visual Basic.

Требования

В этой статье предполагается, что вы знакомы со следующими разделами:

  • Visual C#
  • Терминология XML
  • Создание и чтение XML-файла
  • Синтаксис языка XML-пути (XPath)

Использование класса XPathNavigator для навигации по XML

  1. Создание консольного приложения Visual C# в Visual Studio.

    Примечание.

    В этом примере используется файл с именемBooks.xml. Вы можете создать собственный файлBooks.xml или использовать пример, включенный в краткие руководства по пакету SDK для .NET. Если вы не установили быстрые руководства и не хотите их устанавливать, см. раздел Ссылки для расположения загрузкиBooks.xml . Если у вас установлены краткие руководства, Books.xml находится в следующей папке:
    \Program Files\Microsoft.NET\FrameworkSDK\Samples\Quickstart\Howto\Samples\Xml\Transformxml\VB

    Вы можете скопировать Books.xml в папку \Bin\Debug , расположенную под папкой, в которой был создан этот проект.

  2. Убедитесь, что проект ссылается на System.Xml пространство имен.

  3. Используйте инструкцию using для Xml пространств имен и XPath , чтобы не требовалось квалифицировать объявления в этих пространствах имен позже в коде. Оператор можно использовать using перед любыми другими объявлениями следующим образом:

    using System.Xml;
    using System.Xml.XPath;
    
  4. Объявите соответствующие переменные. Объявите XPathDocument объект для хранения XML-документа и объект для вычисления XPath выражений XPathNavigator и перемещения по документу. Объявите String объект для хранения XPath выражения. Добавьте код объявления в процедуру Main в Module1.

    XPathNavigator nav;
    XPathDocument docNav;
    
  5. XPathDocument Загрузите объект с примером файла Books.xml. Класс XPathDocument использует расширяемые преобразования языка таблиц стилей (XSLT), чтобы обеспечить быстрый и ориентированный на производительность кэш для обработки XML-документов. Она похожа на объектную модель xml-документов (DOM), но хорошо оптимизирована для обработки XSLT и модели данных XPath.

    // Open the XML.
    docNav = new XPathDocument(@"c:\books.xml");
    
  6. Создайте XPathNavigator объект из документа. XPathNavigator позволяет перемещаться по узлам атрибутов и узлам пространства имен в XML-документе.

    // Create a navigator to query with XPath.
    nav = docNav.CreateNavigator();
    
  7. Перейдите в корень документа с помощью MoveToRoot метода . MoveToRoot задает для навигатора узел документа, содержащий все дерево узлов.

    //Initial XPathNavigator to start at the root.
    nav.MoveToRoot();
    
  8. Используйте метод для MoveToFirstChild перемещения в дочерние элементы XML-документа. Метод MoveToFirstChild перемещается к первому дочернему элементу текущего узла. Если источник Books.xml , вы переходите от корневого документа к дочерним элементам, разделу Comment и узлу Bookstore.

    //Move to the first child node (comment field).
    nav.MoveToFirstChild();
    
  9. Используйте метод для MoveToNext итерации узлов на уровне одноуровневого уровня. Метод MoveToNext перемещается в следующий одноуровневый элемент текущего узла.

    //Loop through all of the root nodes.
    do
    {
    } while (nav.MoveToNext());
    
  10. NodeType Используйте свойство , чтобы убедиться, что обрабатываются только узлы элементов, а свойство — Value для отображения текстового представления элемента.

    do
    {
       //Find the first element.
       if (nav.NodeType == XPathNodeType.Element)
       {
            //Determine whether children exist.
            if (nav.HasChildren == true)
            {
                //Move to the first child.
                nav.MoveToFirstChild();
    
                //Loop through all the children.
                do
                {
                    //Display the data.
                    Console.Write("The XML string for this child ");
                    Console.WriteLine("is '{0}'", nav.Value);
                } while (nav.MoveToNext());
            }
        }
    } while (nav.MoveToNext());
    
  11. Используйте свойство , HasAttributes чтобы определить, имеет ли узел какие-либо атрибуты. Вы также можете использовать другие методы, например MoveToNextAttribute, для перемещения к атрибуту и проверки его значения.

    Примечание.

    Этот сегмент кода проходит только по потомкам корневого узла, а не по всему дереву.

    do
    {
       //Find the first element.
       if (nav.NodeType == XPathNodeType.Element)
       {
            //if children exist
            if (nav.HasChildren == true)
            {
                //Move to the first child.
                nav.MoveToFirstChild();
                //Loop through all the children.
                do
                {
                    //Display the data.
                    Console.Write("The XML string for this child ");
                    Console.WriteLine("is '{0}'", nav.Value);
    
                    //Check for attributes.
                    if (nav.HasAttributes == true)
                    {
                        Console.WriteLine("This node has attributes");
                    }
                } while (nav.MoveToNext());
            }
        }
    } while (nav.MoveToNext());
    
  12. ReadLine Используйте метод объекта , Console чтобы добавить паузу в конце экрана консоли, чтобы быстрее отобразить приведенные выше результаты.

    //Pause.
    Console.ReadLine();
    
  13. Выполните сборку и запуск проекта Visual C#.

Полный список кода

using System;
using System.Xml;
using System.Xml.XPath;

namespace q308343
{
    class Class1
    {
        static void Main(string[] args)
        {
            XPathNavigator nav;
            XPathDocument docNav;

            docNav = new XPathDocument(@"c:\books.xml");
            nav = docNav.CreateNavigator();
            nav.MoveToRoot();

            //Move to the first child node (comment field).
            nav.MoveToFirstChild();

            do
            {
                //Find the first element.
                if (nav.NodeType == XPathNodeType.Element)
                {
                    //Determine whether children exist.
                    if (nav.HasChildren == true)
                    {
                        //Move to the first child.
                        nav.MoveToFirstChild();
                        //Loop through all of the children.
                        do
                        {
                            //Display the data.
                            Console.Write("The XML string for this child ");
                            Console.WriteLine("is '{0}'", nav.Value);
                            //Check for attributes.
                            if (nav.HasAttributes == true)
                            {
                                Console.WriteLine("This node has attributes");
                            }
                        } while (nav.MoveToNext());
                    }
                }
            } while (nav.MoveToNext());
            //Pause.
            Console.ReadLine();
        }
    }
}

Устранение неполадок

При тестировании кода может появилось следующее сообщение об ошибке исключения:

Необработанное исключение типа System.Xml. XmlException произошло в system.xml.dll
Дополнительные сведения: Неожиданное объявление XML. Объявление XML должно быть первым узлом в документе, и перед ним не могут отображаться символы пробелов. Строка 1, позиция

Ошибка исключения возникает в следующей строке кода:

docNav = new XPathDocument("c:\\books.xml");

Чтобы устранить эту ошибку, удалите символы с пробелами, которые предшествуют первому узлу в документе books.xml.

Ссылки