我正在尝试从网站读取 XML-RSS-Feed。因此我使用异步下载并创建一个XDocument
与XDocument.Parse()
Method.
该文档的目的非常简单,如下所示:
<root>
<someAttribute></SomeAttribute>
<item>...</item>
<item>...</item>
</root>
现在我想读出所有的项目。因此我尝试:
foreach (XElement NewsEntry in xDocument.Descendants("item"))
但这行不通。所以我在这个板找到了一个帖子使用限定名称,因为根元素中定义了一些命名空间:
<?xml version="1.0" encoding="ISO-8859-1" ?>
<rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns="http://purl.org/rss/1.0/">
好吧,我尝试了所有 3 个可用的命名空间 - 对我来说没有任何效果:
XName itemName = XName.Get("item", "http://www.w3.org/1999/02/22-rdf-syntax-ns#");
XName itemName2 = XName.Get("item", "http://purl.org/dc/elements/1.1/");
XName itemName3 = XName.Get("item", "http://purl.org/rss/1.0/modules/syndication/");
任何帮助,将不胜感激。
(通常我使用 Regex 进行 XML 分析 - 但这次我正在为移动设备进行开发,因此需要关心性能。)