Webサイトから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/");
どんな助けでもいただければ幸いです。(通常、私は正規表現を使用してXML分析を行っていますが、今回はモバイルデバイス用に開発しているため、パフォーマンスに注意する必要があります。)