Используя LINQ, как мне загрузить иерархический XML в POCO? - PullRequest
2 голосов
/ 08 февраля 2012

Я хочу построить объект C # из иерархических данных XML, используя LINQ.Я загрузил 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 Ответ

5 голосов
/ 08 февраля 2012

У вас есть два варианта.

  1. Используйте сериализацию .NET, в этом случае вам необходимо указать сопоставления XML, украсив класс POCO соответствующими атрибутами (имя свойства & rlarr; имя элемента 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();
    
...