LINQ to XML如何获取根的子代,然后再得到子代?

时间:2019-03-30 16:04:48

标签: c# linq-to-xml

我有一个这样定义的XML模式:

<PeopleContainer>
  <People>
    <Person Name="John Doe" Age="27" CauseOfAwesome="King of All Cosmos" />
    <Person Name="Ally McBeagle" Age="7" CauseOfAwesome="Adorable" />
    <Person Name="Bender Rodriguez" Age"249" CauseOfAwesome="Bending" />  
  </People>
</PeopleContainer

我想做的是将People标签作为IEnumerable来抓取,以便将其通过管道传递到我的应用程序中,但是我还没有看到这种情况的选择。

我一直在尝试这样的事情:

XDocument xdoc = XDocument.Load(path);
var people = from p in xdoc.Descendants("People")
             select new
             {
               Name = p.Attribute("Name").Value,
               Age = p.Attribute("Age").Value,
               CauseOfAwesome = p.Attribute("CauseOfAwesome")
             };
foreach (var p in people)
{
   Console.WriteLine(p);
}

我认为我可能错误地实例化了people ...

1 个答案:

答案 0 :(得分:0)

您忘记设置元素人:

        var people = from p in xdoc.Root.Descendants("People")
            select new
            {
                Name = p.Element("Person").Attribute("Name").Value,
                Age = p.Element("Person").Attribute("Age").Value,
                CauseOfAwesome = p.Element("Person").Attribute("CauseOfAwesome")
            };

        foreach (var n in people)
        {
            Console.WriteLine(n.Name);
            Console.WriteLine(n.Age);
            Console.WriteLine(n.CauseOfAwesome);
        }