在C#中解析XML文档
复制:这是最佳实践来解析XML文件和C#?以及许多其他(请参阅http://stackoverflow.com/search?q=c%23+parse+xml).请关闭它,不回答。
Duplicate: This is a duplicate of Best practices to parse xml files with C#? and many others (see http://stackoverflow.com/search?q=c%23+parse+xml). Please close it and do not answer.
如何从下向上解析XML文档中的C#?
How do you parse XML document from bottom up in C#?
例如:
<Employee>
<Name> Test </name>
<ID> 123 </ID>
<Employee>
<Company>
<Name>ABC</company>
<Email>test@ABC.com</Email>
</company>
像这些有很多nodes..I需要开始从下向上解析解析like..first &LT;的公司和GT;
,然后等on..How DOI去这在C#?
Like these there are many nodes..I need to start parsing from bottom up like..first parse <company>
and then and so on..How doi go about this in C# ?
试试这个:
XmlDocument doc = new XmlDocument();
doc.Load(@"C:\Path\To\Xml\File.xml");
或者相反,如果你在一个字符串的XML使用的loadXML
方法。
Or alternatively if you have the XML in a string use the LoadXml
method.
一旦你拥有了它加载,你可以使用的SelectNodes
和的SelectSingleNode
查询特定的值,例如:
Once you have it loaded, you can use SelectNodes
and SelectSingleNode
to query specific values, for example:
XmlNode node = doc.SelectSingleNode("//Company/Email/text()");
// node.Value contains "test@ABC.com"
最后,注意,XML是无效的,因为它不包含一个根节点。它必须是这样的:
Finally, note that your XML is invalid as it doesn't contain a single root node. It must be something like this:
<Data>
<Employee>
<Name>Test</Name>
<ID>123</ID>
</Employee>
<Company>
<Name>ABC</Name>
<Email>test@ABC.com</Email>
</Company>
</Data>