尽管有效的XPath查询,iterator.MoveNext()仍返回false

时间:2012-02-07 14:48:17

标签: c# .net xpath

这个XPath查询我做错了什么?在Feed标记内,有多个条目标记。 XML是有效的,生成的XPath查询也是如此,我已经使用一个名为XPath Visualizer的工具测试了它们。

对iterator.MoveNext()的调用返回false,并且在操作之后,迭代器仍在根节点上。我错过了一些明显的东西吗?

var stringReader = new StringReader(importData.Trim());

        var xpathDoc = new XPathDocument(stringReader);

        XPathNavigator xPathNav = xpathDoc.CreateNavigator();

        string xPathString = "//" + masterNode; // Evaluates to '//entry'

        XPathExpression xPathExpr = xPathNav.Compile(xPathString);

        XPathNodeIterator iterator = xPathNav.Select(xPathExpr);

        while (iterator.MoveNext())
        {
           ....

示例XML

<?xml version="1.0" encoding="UTF-8"?>
            <feed xmlns="http://www.w3.org/2005/Atom" xmlns:g="http://base.google.com/ns/1.0">
                <title>Test</title>
                <link rel="self" href="http://store.Test.com"/>
                <updated>2012-02-07T11:15:04Z</updated>
                <author>
                    <name>Test</name>
                </author>
                <id>tag:000000</id>
    <entry>
        <title><![CDATA[Example 7500cl]]></title>
        <link><![CDATA[http://store.test.com/example-75cl/]]></link>
        <description><![CDATA[example descr........]]></description>
    </entry>

2 个答案:

答案 0 :(得分:4)

问题在于命名空间 - 没有任何entry个元素没有命名空间 - 你可以看到的元素有“http://www.w3.org/2005/Atom”命名空间继承自根

就我个人而言,我会使用LINQ to XML,但如果必须使用XPath,则需要使用命名空间管理器来查找具有特定命名空间的元素。在Stack Overflow中搜索“xpath namespace .net”将为您提供大量带选项的命中。

LINQ to XML代码如下所示:

XDocument doc = XDocument.Parse(importData.Trim());
XNamespace ns = "http://www.w3.org/2005/Atom";
var entries = doc.Descendants(ns + "entry");
foreach (var entry in entries)
{
    ...
}

答案 1 :(得分:1)

我能想到的只是添加一个XmlNamespaceManager。