我有一个如下格式的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并获得report节点,然后从那里得到title/pdflink/size等子节点,它们将是直通的。使用for循环进行循环。我想用xmltextreader来补充这一点。我尝试使用while,但在迭代后只得到一个循环。我不知道为什么。如果通过for循环,我如何迭代like,for(loop when reader.element("reports)){},然后获取剩余的节点,并将它们放在一个数组或列表中。一旦我将它们存储在列表中,我会希望在提要中显示它们。这是一个最好的方法吗?请帮助。
发布于 2012-08-10 02:45:46
在我的例子中,我担心加载大型文档的性能。我所做的就是在我的对象上定义一个构造函数来接收一个XmlReader,并在读取器到达一个完整的节点后将它传递回来。
这允许我在读取对象时为每个对象返回一个填充的对象作为IEnumerable。然后,我启动一个新的Task/Thread来处理单个项目,然后返回到处理文件。
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;
}
}我非常感谢来自其他社区的任何反馈,如果有更好的方法或者这里有任何错误,请让我知道。
https://stackoverflow.com/questions/11889233
复制相似问题