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

本文关键字:加载 XML POCO 分层 LINQ 使用 | 更新日期: 2023-09-27 18:23:55

我想使用LINQ从分层XML数据构建一个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; }
}

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

您有两个选项。

  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();