我正在构建一个需要运行XML feed的应用程序,但是我在获取某些元素方面遇到了一些麻烦.
我正在使用Twitter提要并想要浏览所有<item>元素.我可以很好地连接并从feed中获取内容但我无法弄清楚item当我循环时如何只选择元素reader.Read();.
谢谢你的帮助!
最简单的方法是使用XPath.示例要遵循.
string xml = @"<?xml version=""1.0"" encoding=""UTF-8""?>
<rss version=""2.0"">
<channel>
<title>Twitter public timeline</title>
<link>http://twitter.com/public_timeline</link>
<description>Twitter updates from everyone!</description>
<language>en-us</language>
<ttl>40</ttl>
<item>
<title>yasu_kobayashi: rTwT: @junm : yayaya</title>
<description>yasu_kobayashi: rTwT: @junm : yayaya</description>
<pubDate>Tue, 28 Oct 2008 12:04:48 +0000</pubDate>
<guid>http://twitter.com/yasu_kobayashi/statuses/978829930</guid>
<link>http://twitter.com/yasu_kobayashi/statuses/978829930</link>
</item><item>
<title>FreeGroup: WikiFortio - foobar http://tinyurl.com/5gvttf</title>
<description>FreeGroup: WikiFortio - foobar
http://tinyurl.com/5gvttf</description>
<pubDate>Tue, 28 Oct 2008 12:04:47 +0000</pubDate>
<guid>http://twitter.com/FreeGroup/statuses/978829929</guid>
<link>http://twitter.com/FreeGroup/statuses/978829929</link>
</item></channel></rss>
";
XPathDocument doc = new XPathDocument(new StringReader(xml));
XPathNavigator nav = doc.CreateNavigator();
// Compile a standard XPath expression
XPathExpression expr;
expr = nav.Compile("/rss/channel/item");
XPathNodeIterator iterator = nav.Select(expr);
// Iterate on the node set
try
{
while (iterator.MoveNext())
{
XPathNavigator nav2 = iterator.Current.Clone();
nav2.MoveToChild("title","");
Console.WriteLine(nav2.Value);
nav2.MoveToParent();
nav2.MoveToChild("pubDate","");
Console.WriteLine(nav2.Value);
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
Console.ReadKey();
Run Code Online (Sandbox Code Playgroud)
这是jan的方法
XmlDocument doc2 = new XmlDocument();
doc2.LoadXml(xml);
XmlNode root = doc2.DocumentElement;
foreach (XmlNode item in root.SelectNodes(@"/rss/channel/item"))
{
Console.WriteLine(item.SelectSingleNode("title").FirstChild.Value);
Console.WriteLine(item.SelectSingleNode("pubDate").FirstChild.Value);
}
Run Code Online (Sandbox Code Playgroud)
替代:
// starts as in Vinko Vrsalovic 's answer
// and not including decent eror handling
XmlDocument doc = new XmlDocument(new StringReader(xml));
foreach (XmlNode item in doc.SelectNodes(@"/rss/channel/item"))
{
Console.WriteLine(item.SelectSingleNode("title").Value);
Console.WriteLine(item.SelectSingleNode("pubDate").Value);
}
Run Code Online (Sandbox Code Playgroud)
我不知道这段代码是慢一点还是不好练习.请做评论.
我发现它比使用Navigator和Iterator的另一个更具可读性.
编辑:我使用Xml文档.像Vinko Vrsalovic的回答中的XPath文档不支持这种工作方式,但速度要快得多: (MSDN)
| 归档时间: |
|
| 查看次数: |
12155 次 |
| 最近记录: |