简体   繁体   English

读取大型XML文件

[英]Reading large XML file

I have many xml files with the following structure 我有许多具有以下结构的xml文件

<main.....>
 <raw...>
  <A>field 1</A>
  <B>field 2</B>
  ....
  <interval>
   <type>data</type>
   <type>data</type>
  </interval>
  <interval>
   <type>data</type>
   <type>data</type>
  </interval>
  <interval2>
   <acel>data i need</acel>
   <decel>data i need</decel>
   <left>data i need</left>
   <right>data i need</right>
   <range>tsw</range>
  </interval2>
  <interval2>
   <acel>data i need</acel>
   <decel>data i need</decel>
   <left>data i need</left>
   <right>data i need</right>
   <range>xyz</range>
  </interval2>
 </raw>
 ...
 </raw>
 <raw>
 ...
 </raw>
</main>

I need data from A, and interval2 children acel,decel,lef,right for every raw node in main, I dont know much about XML. 我需要来自A的数据,并且对main中的每个原始节点而言,interval2的子级分别是acel,decel,lef,le,我对XML不太了解。 I've gotten to where i get A for every raw, but no further. 我已经到了我每生一个都能得到A的地方,但是没有更多。

The simplest way in C# - if you're using .NET 3.5 or higher - is to use LINQ to XML: C#中最简单的方法(如果使用的是.NET 3.5或更高版本)是使用LINQ to XML:

XDocument doc = XDocument.Load("file.xml");
var query = doc.Descendants("raw")
               .Select(raw => new {
                           A = (string) raw.Element("A"),
                           Interval2 = raw.Element("interval2")
                                          .Elements("type2")
                                          .Select(type2 => (string) type2)
                                          .ToList()
                       });

foreach (var item in query)
{
    Console.WriteLine("A: {0}", item.A);
    Console.WriteLine("Interval2 values:");
    foreach (var x in item.Interval2)
    {
        Console.WriteLine("  {0}", x);
    }
}

Of course that's just one way of querying it - it's hard to give a more concrete answer without more information about what you're trying to do. 当然,这只是查询它的一种方式-如果没有更多有关您要执行的操作的信息,很难给出更具体的答案。

The simplest way is to use XmlDocument. 最简单的方法是使用XmlDocument。 However, this reads the entire file into memory so would not be appropriate for immensely large files. 但是,这会将整个文件读入内存,因此不适用于超大文件。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM