我有一个以下格式的xml。
<?xml version="1.0" encoding="UTF-8" standalone= "yes"?>
<rss>
<report name="rpt1">
<title>AAA</title>
<image></image>
<weblink></weblink>
<pdflink></pdflink>
<pdfsize></pdfsize>
</report>
<report name="rpt2">
<title>BBB</title>
<image>CCC</image>
<weblink>DDD</weblink>
<pdflink>EEE</pdflink>
<pdfsize>FFF</pdfsize>
</report>
</rss>
现在我想迭代这个 xml 并获取报告节点,然后从那里获得子节点,如标题/pdf链接/大小等,这些子节点将通过 for 循环进行循环。
我想使用xmltextreader来完成此操作。我尝试使用 while 但迭代后我只得到 1 个循环。我不知道为什么。如果通过 for 循环,我如何迭代,
for(loop when reader.element("reports)){}
,然后获取其余节点并将它们放在数组或列表中左右。一旦我将它们存储在列表中,我就会想在提要中显示它们。
最好的方法是什么?请帮忙。
就我而言,我担心加载大型文档的性能。 我所做的是在对象上定义一个构造函数来接收 XmlReader 并 hydrate - 在读取器到达完整节点后将其传递回去。
这允许我在读取每个对象时将填充的对象作为 IEnumerable 返回。 然后,我启动一个新的任务/线程来处理该单个项目,并返回到处理文件。
private IEnumerable<Report> readReports(Stream reader)
{
var settings = new XmlReaderSettings();
settings.IgnoreWhitespace = true;
var xmlReader = XmlReader.Create(reader, settings);
xmlReader.MoveToContent();
xmlReader.Read();
while (!xmlReader.EOF)
{
if (xmlReader.Name.ToUpper() == "report")
yield return new Report(xmlReader);
xmlReader.Read();
}
}
public Report(XmlReader reader) : this()
{
reader.MoveToContent();
if (reader.IsEmptyElement)
{
reader.Read();
return;
}
reader.Read();
while (!reader.EOF)
{
if (reader.IsStartElement())
{
switch (reader.Name.ToLower())
{
case "order_id":
this.OrderId = reader.ReadElementContentAsString();
break;
// abreviated the rest of the fields
default:
reader.Skip();
break;
}
}
else if (reader.Name.ToLower() == "report") //this watches for the end element of the container and returns after populating all properties
return;
}
}
我绝对感谢社区其他成员的任何反馈,如果有更好的方法或这里有任何错误,请告诉我。