假设我有以下Xml:
<Sections>
<Section>
<Item>
<Field> myfield </Field>
<Field> myfield </Field>
</Item>
<Item>
<Field> myfield </Field>
<Field> myfield </Field>
</Item>
</Section>
<Section>
<Item>
<Field> myfield </Field>
<Field> myfield </Field>
</Item>
</Section>
</Sections>
现在我想要的是循环通过Sections,并分别处理每个项目,所以我想做类似以下的事情:
reader.ReadToDescendant("Section")
do
{
Console.WriteLine("Section");
reader.ReadToDescendant("Item");
do
{
var element = (XElement)XNode.ReadFrom(reader);
foreach (XElement el in element.Elements())
{
Console.WriteLine(el.Value);
}
}while(reader.ReadToNextSibling("Item"));
}while (reader.ReadToNextSibling("Section"))
我的问题是。如果我为Item节点重复相同的do-while循环,读取器何时找到关闭的Section标签或者它将搜索所有xml?我应该在内循环之前使用reader.ReadSubtree()吗?
请注意,我不是在寻找像“使用XDocument”这样的标准答案。我知道dom更容易使用,但它们不适合我的情况
答案 0 :(得分:2)
使用ReadSubtree
创建内部阅读器以使用当前节点。如果没有这个,读者将不会停止并继续搜索,直到文档结束。
reader.ReadToDescendant("Section");
do
{
Console.WriteLine("Section");
using (var innerReader = reader.ReadSubtree())
{
while (innerReader.ReadToFollowing("Field"))
{
Console.WriteLine("field");
}
}
} while (reader.ReadToNextSibling("Section"));