我正在尝试解析xml文件
我的代码如下:
string path2 = "xmlFile.xml";
XmlDocument xDoc = new XmlDocument();
xDoc.Load(path2);
XmlNodeList xnList = xDoc.DocumentElement["feed"].SelectNodes("entry");
但似乎无法获得节点列表。我收到错误消息 - “使用'new'关键字创建一个对象实例。”它似乎在'SelectNodes(“entry”)' 当我从rss feed加载xml而不是本地文件时,此代码有效。你能告诉我我做错了什么吗?
我的xml看起来像:
<?xml version="1.0"?>
<feed xmlns:media="http://search.yahoo.com/mrss/" xmlns:gr="http://www.google.com/schemas/reader/atom/" xmlns:idx="urn:atom-extension:indexing" xmlns="http://www.w3.org/2005/Atom" idx:index="no" gr:dir="ltr">
<entry gr:crawl-timestamp-msec="1318667375230">
<title type="html">Title 1 text</title>
<summary>summary 1 text text text</summary>
</entry>
<entry gr:crawl-timestamp-msec="1318667375230">
<title type="html">title 2 text</title>
<summary>summary 2 text text text</summary>
</entry>
</feed>
答案 0 :(得分:1)
考虑名称空间:
答案 1 :(得分:1)
这是臭名昭着的大多数关于XPath的常见问题解答 - 指的是默认命名空间中元素的名称。
简短回答:搜索“XPath默认命名空间”并了解问题。
然后使用 XmlNamespaceManager
实例添加前缀(例如"x"
)与默认命名空间(在您的情况下)之间的关联{ {1}})。
最后,将任何 "http://www.w3.org/2005/Atom"
替换为XPath表达式中的 Name
。