xmlserializer可直接反序列化xml为list,需确保xml有外层根元素(如)、类用[xmlroot]和[xmlelement]标记、序列化器传入具体容器类型(如itemlist)。

用 XmlSerializer 可以直接把 XML 反序列化成 List<t></t>,关键是要让 XML 结构和类定义匹配,并正确处理根节点。
确保 XML 有合适的根节点
XML 必须有一个**外层根元素**(比如 <items></items>),里面包裹多个同级子元素(比如多个 <item></item>),否则 XmlSerializer 无法识别为列表。
✅ 正确示例:
定义匹配的类结构
被反序列化的类不需要特别标记,但建议加 [XmlRoot] 和 [XmlElement] 明确映射关系:
-
[XmlRoot("Items")]标记整个列表的根节点名 -
[XmlElement("Item")]标记每个列表项对应的 XML 元素名 - 属性名默认对应子元素名(如
public string Name { get; set; }→<name></name>)
示例类:
[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<item>)</item> —— 因为泛型开放类型不能直接用。
- 推荐封装一个具体类型(如
ItemList)继承List<item></item> - 用
StringReader或FileStream加载 XML 源 - 反序列化后强转为
List<item></item>即可使用
代码片段:
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<item></item>
这种方式更灵活,适合临时解析场景。
基本上就这些。核心是 XML 结构、类标记、序列化器类型三者对齐,不复杂但容易忽略根节点和类型匹配。









