0

我有以下格式的 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(loop when reader.element("reports)){} 然后获取其余节点并将它们放入数组或列表中。一旦我将它们存储在列表中我想在提要中对它们进行 dipaly。这是最好的方法吗?请帮忙。

4

1 回答 1

0

就我而言,我担心加载大型文档的性能。我所做的是在我的对象上定义一个构造函数来接收 XmlReader 和水合物 - 在阅读器到达完整节点后将其传回。

这使我可以在读取每个对象时将填充的对象返回为 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;
    }
}

如果有更好的方法或者这里有任何错误,请让我知道,我绝对会感谢社区其他人的任何反馈。

于 2012-08-09T18:45:46.357 回答