3

我正在尝试<thumbnail_large>http://b.vimeocdn.com/ts/235/662/23566238_640.jpg</thumbnail_large>从创建的 xml 文件中的 thumbnail_large 元素中提取值。有没有办法在不遍历 who xml 文件的情况下提取该值?谢谢你的帮助。

<videos>
    <video>
        <id>6271487</id>
        <title>Spheres</title>
        <description>text</description>
        <url>http://vimeo.com/6271487</url>
        <thumbnail_small>http://b.vimeocdn.com/ts/235/662/23566238_100.jpg</thumbnail_small>
        <thumbnail_medium>http://b.vimeocdn.com/ts/235/662/23566238_200.jpg</thumbnail_medium>
        <thumbnail_large>http://b.vimeocdn.com/ts/235/662/23566238_640.jpg</thumbnail_large>
        <embed_privacy>anywhere</embed_privacy>
    </video>
</videos>
4

3 回答 3

9

是的,有,它被称为 XPath。尝试这个:

XmlDocument doc = new XmlDocument();
doc.Load(@"/path/to/file");
XmlNode node = doc.SelectSingleNode("/videos/video/thumbnail_large");
string URI = node.InnerText;

至少这是我可以从这个格式不佳的文件中读取的内容。如果您使用两种不同的字母(视频详细信息和 HTML 标记),您应该考虑使用命名空间。

于 2012-08-31T00:27:13.993 回答
4

看着:

  1. 对于 .NET Framework 3.5+ --XDocument
  2. 否则:XmlDocument
于 2012-08-31T00:19:45.273 回答
-4
string s=File.ReadAllText("My.xml");
List<string> urllist= new List<string>();
string val="<thumbnail_large>";
int start= s.IndexOf(val);
while(start!=-1)
{               
start = s.IndexOf(val,start+val.length);
int end = s.IndexOf("</thumbnail_large>",start);
urllist.add(s.Substring(start, end - start -1));
}
于 2012-08-31T00:33:34.120 回答