我正在尝试解析xml文件
我的代码如下:
string path2 = "xmlFile.xml";
XmlDocument xDoc = new XmlDocument();
xDoc.Load(path2);
XmlNodeList xnList = xDoc.DocumentElement["feed"].SelectNodes("entry");
但似乎无法获得节点列表。我得到错误消息-"使用'new'关键字创建对象实例",它似乎是在"SelectNodes("entry")"上。当我从rss提要加载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>
考虑命名空间:
XmlNamespaceManager mgr = new XmlNamespaceManager(XDoc.NameTable);
mgr.AddNamespace("atom", "http://www.w3.org/2005/Atom");
XmlNodeList xnList = xDoc.SelectNodes("//atom:entry", mgr);
这是关于XPath最臭名昭著的常见问题——引用默认名称空间中的元素名称。
简短的回答:搜索"XPath默认命名空间"并理解问题。
然后使用 XmlNamespaceManager
实例来添加前缀(例如"x"
)和默认命名空间(在您的示例中是"http://www.w3.org/2005/Atom"
)之间的关联。
最后,用 x:Name
替换XPath表达式中的 Name
。