我想从分层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 & baby" description="test" />
<category id="3" name="home & 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; }
}
答案 0 :(得分:5)
您有两种选择。
使用.NET序列化,在这种情况下,您需要通过使用适当的属性(属性名称⇄XML元素名称)修饰POCO类来指定XML映射。
使用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();