这个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>
答案 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。