0

どこが間違っているか分かる人いますか?または、ビデオ名を文字列にするより良い方法はありますか?

string text = "<?xml version='1.0' encoding='UTF-8'?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:media='http://search.yahoo.com/mrss/' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:gd='http://schemas.google.com/g/2005' xmlns:yt='http://gdata.youtube.com/schemas/2007'><entry><title>VIDEO NAME</title></entry></feed>";
string xpath = "feed/entry";
XmlDocument xml = new XmlDocument();
xml.LoadXml(text);
XmlNodeList nodes = xml.SelectNodes(xpath);
foreach (XmlNode node in nodes)
{
    string title = node["title"].InnerText;
    MessageBox.Show(title);
}

XML

<?xml version='1.0' encoding='UTF-8'?>
    <feed xmlns='http://www.w3.org/2005/Atom' xmlns:media='http://search.yahoo.com/mrss/' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:gd='http://schemas.google.com/g/2005' xmlns:yt='http://gdata.youtube.com/schemas/2007'>
      <entry>
        <title>VIDEO NAME</title>
      </entry>
    </feed>
4

3 に答える 3

3

Xml でのこの宣言によりxmlns='http://www.w3.org/2005/Atom' 、名前空間プレフィックスを持たないドキュメント内のすべての要素がデフォルトの名前空間に配置されますhttp://www.w3.org/2005/Atom/。したがって、XPath クエリで名前空間を使用する必要があります。

        string text = "<?xml version='1.0' encoding='UTF-8'?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:media='http://search.yahoo.com/mrss/' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:gd='http://schemas.google.com/g/2005' xmlns:yt='http://gdata.youtube.com/schemas/2007'><entry><title>VIDEO NAME</title></entry></feed>";

        XmlDocument xml = new XmlDocument();
        xml.LoadXml(text);
        XmlNamespaceManager nsmgr = new System.Xml.XmlNamespaceManager(xml.NameTable);
        nsmgr.AddNamespace("atom", "http://www.w3.org/2005/Atom");
        string xpath = "atom:feed/atom:entry/atom:title";
        XmlNodeList nodes = xml.SelectNodes(xpath, nsmgr);

        foreach (XmlNode node in nodes)
        {
            Console.WriteLine(node.InnerText);
        }
于 2013-03-09T13:47:03.103 に答える
1

XmlDocument と XPath の代わりに LINQ to XML を使用できます。

string text = "<?xml version='1.0' encoding='UTF-8'?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:media='http://search.yahoo.com/mrss/' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:gd='http://schemas.google.com/g/2005' xmlns:yt='http://gdata.youtube.com/schemas/2007'><entry><title>VIDEO NAME</title></entry></feed>";
var doc = XDocument.Parse(text);
var atom = XNamespace.Get("http://www.w3.org/2005/Atom");

var titles = doc.Descendants(atom + "entry")
                .Select(e => (string)e.Element(atom + "title"))
                .ToList();

foreach (string title in titles)
    Console.WriteLine(title);
于 2013-03-09T13:53:05.597 に答える
0

これは機能しますが、私が作成したコードは非常に汚いハックのように感じます

        string text = "<?xml version='1.0' encoding='UTF-8'?><feed xmlns='http://www.w3.org/2005/Atom' xmlns:media='http://search.yahoo.com/mrss/' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:gd='http://schemas.google.com/g/2005' xmlns:yt='http://gdata.youtube.com/schemas/2007'><entry><title>VIDEO NAME</title></entry></feed>";
        XmlDocument xml = new XmlDocument();
        xml.LoadXml(text);
        XmlNode parentNode = xml.GetElementsByTagName("feed").Item(0);
        foreach (XmlNode n in parentNode.ChildNodes)
        {
            string title = n["title"].InnerText;
            Console.WriteLine(title);
        }

        Console.ReadLine();
于 2013-03-09T13:44:34.757 に答える