[英]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.