我有以下格式的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并获取报告节点,并从那里获得像title / pdflink / size等的子节点。使用for循环循环。我想用xmltextreader来配合这个。我尝试使用while但迭代后我只得到1个循环。我不知道为什么。如果通过for循环我如何迭代, for(循环当reader.element(“reports)){}然后得到其余的节点并将它们放在一个数组或列表左右。一旦我把它们存储在列表中,我就想把它们放在一个feed中。这是最好的方法吗?请帮助。
答案 0 :(得分:0)
在我的情况下,我担心加载大型文档的性能。我所做的是在我的对象上定义一个构造函数来接收一个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;
}
}
我肯定会感谢社群其他人的反馈,如果有更好的方法,或者如果有任何错误,请告诉我。