0

我有一个XPathNodeIterator名为_xpCategories的数据,其中包含这样的数据

        <root>
      <category numberofproducts="0">
        <id>hoved</id>
        <url>/products/hovednavigation</url>
        <name>HOVEDNAVIGATION</name>
        <category numberofproducts="0">
          <id>embalfors</id>
          <url>/products/emballage-og-forsendelse</url>
          <name>Emballage og forsendelse</name>
          <category numberofproducts="0">
            <id>gaveindpak</id>
            <url>/products/gaveindpakning</url>
            <name>Gaveindpakning</name>
            <category numberofproducts="3">
              <id>cellofan</id>
              <url>/products/cellofan</url>
              <name>Cellofan</name>
            </category>
            <category numberofproducts="30">
              <id>gavebånd</id>
              <url>/products/gavebaand</url>
              <name>Gavebånd</name>
            </category>
          </category>
          <category numberofproducts="0">
            <id>kuvkonv</id>
            <url>/products/kuverter-og-konvolutter</url>
            <name>Kuverter og konvolutter</name>
          </category>
          </category>
      </category>
</root>

我想遍历这个xml中的每个类别并打印每个类别的id。我做了一些这样的代码。

 while (_xpCategories.MoveNext())
    {
        Console.WriteLine(_xpCategories.Current.SelectSingleNode("id"));

    }

但是这个循环只能工作一个,只有第一个类别 id 得到,然后它存在循环。有人能指出我做错了什么吗?

4

2 回答 2

1

您可以像这样将 XPathNavigator 与 XPathNodeIterator 一起使用

(此处的修改示例)

XPathDocument document = new XPathDocument("yourxml.xml");
XPathNavigator navigator = document.CreateNavigator();

XPathNodeIterator _xpCategories = navigator.Select("//category");
_xpCategories.MoveNext();

while (nodesText.MoveNext())
    Console.WriteLine(nodesText.Current.Value);
于 2013-10-10T12:11:35.413 回答
1

您需要修改XPath表达式以选择文档中的所有类别,无论它们在文档中的哪个位置,因为您有 1 个带有子类别的父类别,然后是这些子类别中的子类别。

/root/category- 这将只选择具有许多子节点的父类别节点(1 个节点)。

//category- 这应该选择 XML 文档中的所有类别,无论它们出现在哪里。

看看这里这里以获得更多帮助

于 2013-10-10T12:19:25.953 回答