我正在尝试从网站读取 XML-RSS-Feed。因此,我使用异步下载并使用 XDocument 方法创建一个 XDocument.Parse()

该文档打算非常简单,如下所示:

<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 分析 - 但这次我正在为移动设备开发,因此需要关心性能。)

最佳答案

您还没有尝试过 rdf 声明末尾的 default namespace:

xmlns="http://purl.org/rss/1.0/"

这是有道理的,因为默认命名空间中的任何元素都不需要在元素名称之前添加命名空间。

关于c# - XDocument.Descendants(itemName) - 查找限定名称的问题,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3924305/

10-12 04:28