使用多个NS读取XML文件

时间:2011-11-22 17:49:48

标签: c# xml

我正在尝试阅读XML Feed以获取上次发布日期。我的xml看起来像这样:

<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
    xmlns:content="http://purl.org/rss/1.0/modules/content/"
    xmlns:wfw="http://wellformedweb.org/CommentAPI/"
    xmlns:dc="http://purl.org/dc/elements/1.1/"
    xmlns:atom="http://www.w3.org/2005/Atom"
    xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
    xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
    >

<channel>
    <title>mysite</title>
    <atom:link href="http://www.mysite.com/news/feed/" rel="self" type="application/rss+xml" />
    <link>http://www.mysite.com/news</link>
    <description>mysite</description>
    <lastBuildDate>Tue, 22 Nov 2011 16:10:27 +0000</lastBuildDate>
    <language>en</language>
    <sy:updatePeriod>hourly</sy:updatePeriod>
    <sy:updateFrequency>1</sy:updateFrequency>
    <generator>http://wordpress.org/?v=3.0.4</generator>
        <item>
        <title>My first post!</title>
        <link>http://www.mysite.com/news/2011/11/22/docstore-v2-released/</link>
        <comments>http://www.mysite.com/news/2011/11/22/docstore-v2-released/#comments</comments>
        <pubDate>Tue, 22 Nov 2011 16:10:27 +0000</pubDate>
        <dc:creator>mysite</dc:creator>
                <category><![CDATA[News]]></category>
        <category><![CDATA[Promotions]]></category>
        <category><![CDATA[docstore]]></category>

我没有显示所有的xml,因为它很长。

到目前为止,我的方法看起来像这样:

    private void button1_Click(object sender, EventArgs e)
    {

        var XmlDoc = new XmlDocument();

        // setup the XML namespace manager
        var mgr = new XmlNamespaceManager(XmlDoc.NameTable);

        // add the relevant namespaces to the XML namespace manager
        mgr.AddNamespace("ns", "http://purl.org/rss/1.0/modules/content/");

        var webClient = new WebClient();
        var stream = new MemoryStream(webClient.DownloadData("http://www.mysite.com/news/feed/"));
        XmlDoc.Load(stream);

        // **USE** the XML anemspace in your XPath !!
        XmlElement NodePath = (XmlElement)XmlDoc.SelectSingleNode("/ns:Response");

        while (NodePath != null)
        {
            foreach (XmlNode Xml_Node in NodePath)
            {
                Console.WriteLine(Xml_Node.Name + ": " + Xml_Node.InnerText);
            }
        }

    }

我遇到问题告诉我:

  

需要命名空间管理器或XsltContext。这个查询有一个前缀,   变量或用户定义的函数。

我想要从这个xml代码中取出的是'lastBuildDate'。我正在试图让这段代码正确。

有人可以告诉我这里做错了吗?

谢谢!

2 个答案:

答案 0 :(得分:4)

您没有使用命名空间管理器。

// **USE** the XML anemspace in your XPath !!         
XmlElement NodePath = (XmlElement)XmlDoc.SelectSingleNode("/ns:Response", mgr); 

答案 1 :(得分:2)

您只需要使用其中一个元素,您可以使用XPath直接访问它。该元素也在默认命名空间中,因此您无需执行任何特殊操作即可。怎么样:

var XPATH_BUILD_DATE="/rss/channel/lastBuildDate";


private void button1_Click(object sender, EventArgs e){
  var xmlDoc = new XmlDocument();
  var webClient = new WebClient();
  var stream = new MemoryStream(webClient.DownloadData("http://www.mysite.com/news/feed/"));
xmlDoc.Load(stream);

XmlElement xmlNode = (XmlElement)xmlDoc.SelectSingleNode(XPATH_BUILD_DATE);

Console.WriteLine(xmlNode.Name + ": " + xmlNode.InnerText);       

}

如果你确实需要挖掘不同命名空间中的元素,你也可以使用XPath(例如,获取dc:creator:

  /rss/channel/item[1]/*[local-name() = 'creator']