如何获取xml文件的所有节点?

时间:2012-05-13 23:25:42

标签: c# xml parsing nodes

假设我有这个XML文件:

<Names>
    <Name>
        <FirstName>John</FirstName>
        <LastName>Smith</LastName>
    </Name>
    <Name>
        <FirstName>James</FirstName>
        <LastName>White</LastName>
    </Name>
</Names>

现在我要打印节点的所有名称:

Names
Name
FirstName
LastName

我设法在XmlNodeList中获取所有内容,但我不知道SelectNodes是如何工作的。

XmlNodeList xnList = xml.SelectNodes(/*What goes here*/);

我想选择所有节点,然后执行xnList的foreach(使用我假设的.Value属性)。

这是正确的做法吗?如何使用selectNodes选择所有节点?

3 个答案:

答案 0 :(得分:2)

确保在范围内具有LINQ和LINQ to XML:

using System.Linq;
using System.Xml.Linq;

如果您将它们加载到XDocument

var doc = XDocument.Parse(xml);    // if from string
var doc = XDocument.Load(xmlFile); // if from file

您可以执行以下操作:

doc.Descendants().Select(n => n.Name).Distinct()

这将为您提供文档中所有不同XName个元素的集合。如果您不关心XML命名空间,可以将其更改为:

doc.Descendants().Select(n => n.Name.LocalName).Distinct()

将为您提供所有不同元素名称的集合作为字符串。

答案 1 :(得分:0)

有几种方法可以做到这一点。

使用XDocument和LINQ-XML

foreach(var name in doc.Root.DescendantNodes().OfType<XElement>().Select(x => x.Name).Distinct()) 
{ 
    Console.WriteLine(name); 
} 

如果您使用的是C#3.0或更高版本,则可以执行此操作

var data = XElement.Load("c:/test.xml"); // change this to reflect location of your xml file 
var allElementNames =  
(from e in in data.Descendants() 
select e.Name).Distinct();

答案 2 :(得分:0)

添加

 using System.Xml.Linq;

然后你可以做

var element = XElement.Parse({Your xml string});

    Console.Write(element.Descendants("Name").Select(el => string.Format("{0} {1}", el.Element("FirstName").Value, el.Element("LastName").Value)));