我有一个包含几个子树的XML文件,这些子树也可以在其中包含子树。像这样:
<File>
<A>...</A>
<B>...</B>
<C>
..
<D>..</D>
</C>
</File>
(".."是子树中的元素)。我怎么能读取每个子树,然后读取它的所有元素(如果这个子树包含子树,我想单独读取它和他的所有元素)?
XmlReader
支持为此目的读取子树;如果您愿意,您可以使用子树阅读器作为其他模型(XmlDocument
, XElement
等)的输入:
using(var reader = XmlReader.Create(source))
{
reader.MoveToContent();
reader.ReadStartElement(); // <File>
while(reader.NodeType != XmlNodeType.EndElement)
{
Console.WriteLine("subtree:");
using(var subtree = reader.ReadSubtree())
{
while(subtree.Read())
Console.WriteLine(subtree.NodeType + ": " + subtree.Name);
}
reader.Read();
}
reader.ReadEndElement(); // </File>
}
可以使用XDocument读取. net中的XML文档。例如,读取D
节点的值:
var doc = XDocument.Load("test.xml");
var value = doc.Root.Element("C").Element("D").Value;
我用下面的代码得到了解决方案
var doc = XDocument.Load("C:\Test.xml");
var DBID = doc.Root.Element("database").FirstAttribute.Name;
var DBIDValue = doc.Root.Element("database").FirstAttribute.Value;