XmlSerializer可直接反序列化XML为List,需确保XML有外层根元素(如)、类用[XmlRoot]和[XmlElement]标记、序列化器传入具体容器类型(如ItemList)。

用 XmlSerializer 可以直接把 XML 反序列化成 List,关键是要让 XML 结构和类定义匹配,并正确处理根节点。
确保 XML 有合适的根节点
XML 必须有一个**外层根元素**(比如 ),里面包裹多个同级子元素(比如多个 ),否则 XmlSerializer 无法识别为列表。
✅ 正确示例:
定义匹配的类结构
被反序列化的类不需要特别标记,但建议加 [XmlRoot] 和 [XmlElement] 明确映射关系:
-
[XmlRoot("Items")]标记整个列表的根节点名 -
[XmlElement("Item")]标记每个列表项对应的 XML 元素名 - 属性名默认对应子元素名(如
public string Name { get; set; }→)
示例类:
[XmlRoot("Items")]public class ItemList : List
public class Item
{
[XmlElement("Name")] public string Name { get; set; }
[XmlElement("Id")] public int Id { get; set; }
}
调用 XmlSerializer 反序列化
创建 XmlSerializer 实例时,传入的是**列表容器类型**(如 typeof(ItemList)),不是 typeof(List —— 因为泛型开放类型不能直接用。
- 推荐封装一个具体类型(如
ItemList)继承List - 用
StringReader或FileStream加载 XML 源 - 反序列化后强转为
List即可使用
代码片段:
var xml = @"var serializer = new XmlSerializer(typeof(ItemList));
using var reader = new StringReader(xml);
var list = (ItemList)serializer.Deserialize(reader);
// list 是 List
替代方案:不定义包装类,用数组反序列化再转列表
如果不想定义额外类,也可以反序列化为 Item[],再调用 .ToList():
- 将类标记为
[XmlRoot("Item")] - 用
new XmlSerializer(typeof(Item[]), new XmlRootAttribute("Items")) - 反序列化后得到
Item[],再转List
这种方式更灵活,适合临时解析场景。
基本上就这些。核心是 XML 结构、类标记、序列化器类型三者对齐,不复杂但容易忽略根节点和类型匹配。









