我正在查看下面的the example,我想知道,在我读完所有image
个节点之后,如何从父元素中读取last_modified_at
节点?
(参见最后几行代码中的评论)
public class StackOverflow_6473251
{
public static void Test()
{
string xml = @"
<movies>
<movie>
<score>8.582207</score>
<popularity>3</popularity>
<translated>true</translated>
<adult>false</adult>
<language>en</language>
<original_name>Transformers</original_name>
<name>Transformers</name>
<alternative_name>The Transformers</alternative_name>
<type>movie</type>
<id>1858</id>
<imdb_id>tt0418279</imdb_id>
<url>http://www.themoviedb.org/movie/1858</url>
<votes>28</votes>
<rating>7.2</rating>
<certification>PG-13</certification>
<overview>The Earth is caught in the middle of an intergalactic war /overview>
<released>2007-07-04</released>
<images>
<image type=""poster"" url=""http://hwcdn.themoviedb.org/posters/304/4bc91347017a3c57fe007304/transformers-original.jpg"" size=""original"" id=""4bc91347017a3c57fe007304""/>
<image type=""poster"" url=""http://hwcdn.themoviedb.org/posters/304/4bc91347017a3c57fe007304/transformers-mid.jpg"" size=""mid"" id=""4bc91347017a3c57fe007304""/>
<image type=""poster"" url=""http://hwcdn.themoviedb.org/posters/304/4bc91347017a3c57fe007304/transformers-cover.jpg"" size=""cover"" id=""4bc91347017a3c57fe007304""/>
<image type=""poster"" url=""http://hwcdn.themoviedb.org/posters/304/4bc91347017a3c57fe007304/transformers-thumb.jpg"" size=""thumb"" id=""4bc91347017a3c57fe007304""/>
<image type=""backdrop"" url=""http://hwcdn.themoviedb.org/backdrops/2ce/4bc91339017a3c57fe0072ce/transformers-original.jpg"" size=""original"" id=""4bc9133s9017a3c57fe0072ce""/>
<image type=""backdrop"" url=""http://hwcdn.themoviedb.org/backdrops/2ce/4bc91339017a3c57fe0072ce/transformers-poster.jpg"" size=""poster"" id=""4bc91339017a3c57fe0072ce""/>
<image type=""backdrop"" url=""http://hwcdn.themoviedb.org/backdrops/2ce/4bc91339017a3c57fe0072ce/transformers-thumb.jpg"" size=""thumb"" id=""4bc91339017a3c57fe0072ce""/>
</images>
<last_modified_at>2010-04-26 03:26:14</last_modified_at>
</movie>
</movies>";
XmlReader r = XmlReader.Create(new StringReader(xml));
r.ReadToFollowing("original_name");
string title = r.ReadElementContentAsString("original_name", r.NamespaceURI);
r.ReadToFollowing("images");
int imageCount = 0;
if (r.ReadToDescendant("image"))
{
do
{
Console.WriteLine("Image {0}", ++imageCount);
Console.WriteLine(" Type: {0}", r.GetAttribute("type"));
Console.WriteLine(" URL: {0}", r.GetAttribute("url"));
Console.WriteLine(" Size: {0}", r.GetAttribute("size"));
Console.WriteLine(" ID: {0}", r.GetAttribute("id"));
} while (r.ReadToNextSibling("image"));
}
//read last_modified_at
//reader.Name evaluates to 'images' at execution time
//reader.NodeType evaluates to 'EndElement' at execution time
}
}
在similar场景中,我试图通过以下答案成功完成相同的结果,但未成功完成,并且在突出显示的行(41)处失败,返回false。
问题是从上一个abbr
转到intervals
。在这里我看不出与上面给出的例子的区别。
更新 Here是一个完整的例子。
答案 0 :(得分:1)
你做不到。来自文档:
“代表提供快速,非缓存,仅向前访问XML数据的读者。”
你可以从头开始阅读。
或者,由于数据非常小,您可以使用XmlDocument,这样可以提供更大的灵活性。
答案 1 :(得分:1)
正如last_modified_at跟随图像一样,你可以按照它的方式进行操作:
r.ReadToFollowing("last_modified_at");
string lastModified = r.ReadElementContentAsString("last_modified_at", r.NamespaceURI);
答案 2 :(得分:0)
在pastebin example,而不是if (reader.Name != "abbreviations")
执行:
if (!reader.ReadToFollowing("abbreviations"))
它失败了,因为你还没有使用缩写标签。
问题中相应的工作代码是:
r.ReadToFollowing("images");
事实上,没有reader.Name !=
测试。