使用LINQ,如何将分层XML加载到POCO中?

时间:2012-02-08 02:16:37

标签: c# xml linq poco

我想从分层XML数据usinq LINQ构建一个C#对象。 我已将XML加载为XDocument(首先将XML从文件读入字符串)。 我需要一些关于如何解析它的指导。

从XML文件读取的示例字符串

<?xml version="1.0" encoding="utf-8" ?>
<categories version="1.0">
  <category id="0" name="women" description="test">
    <category id="01" name="tops" description="test"></category>
    <category id="02" name="bottoms" description="test"></category>
    <category id="03" name="accessories" description="test"></category>
  </category>
  <category id="1" name="men" description="test">
    <category id="11" name="shirts" description="test"></category>
    <category id="12" name="trousers" description="test"></category>
    <category id="13" name="accessories" description="test"></category>
  </category>
  <category id="2" name="kids &amp; baby" description="test" />
  <category id="3" name="home &amp; living" description="test" />
</categories>

我有这样一个POCO课程:

[DataContract]
public class Category
{
    [DataMember]
    public int Id { get; set; }

    [DataMember]
    public string Name { get; set; }

    [DataMember]
    public string Description { get; set; }

    [DataMember]
    public List<Category> SubCategories { get; set; }
}

1 个答案:

答案 0 :(得分:5)

您有两种选择。

  1. 使用.NET序列化,在这种情况下,您需要通过使用适当的属性(属性名称⇄XML元素名称)修饰POCO类来指定XML映射。

  2. 使用LINQ to XML(就像你想要的那样)。在这种情况下,代码看起来像这样:

    var categories = x.Root.Elements().Select(e =>
        new Category
        {
            Id = int.Parse(e.Attribute("id").Value),
            Name = e.Attribute("name").Value,
            Description = e.Attribute("description").Value,
            SubCategories = e.Elements().Select(e1 =>
                new Category
                {
                    Id = int.Parse(e1.Attribute("id").Value),
                    Name = e1.Attribute("name").Value,
                    Description = e1.Attribute("description").Value
                }).ToList()
        }).ToList();
    

    或递归地,通过向您的班级添加递归方法Parse

    public static Category Parse(XElement value)
    {
        return new Category
        {
            Id = int.Parse(value.Attribute("id").Value),
            Name = value.Attribute("name").Value,
            Description = value.Attribute("description").Value,
            SubCategories = value.Elements().Select(newvalue =>  Parse(newvalue)).ToList()
        };
    }
    

    并将其称为:

    var categories = x.Root.Elements().Select(e => Category.Parse(e)).ToList();