最推荐C#操作XML的方式是LINQ to XML,核心类型为XDocument和XElement,支持简洁的创建、加载、查询、修改与保存;使用Elements()/Descendants()查找节点,Where()/First()筛选,(string)安全取值,改完调用Save()持久化。

C#操作XML文件最推荐的方式就是LINQ to XML,它比传统的XmlDocument更简洁、更符合现代C#开发习惯,支持函数式编程风格,读写都直观高效。核心类型是XDocument(对应整个XML文档)和XElement(对应单个元素),无需手动管理节点生命周期,也无需引用老式的System.Xml命名空间中的冗长类。
创建和保存XML文档
用XElement或XDocument直接构建结构,调用Save()即可写入文件。
- 创建根元素并嵌套子元素:
var root = new XElement("Books", new XElement("Book", new XAttribute("id", "1"), new XElement("Title", "C#入门"), new XElement("Author", "张三"))) - 创建完整文档(含声明):
var doc = new XDocument(new XDeclaration("1.0", "utf-8", "yes"), root) - 保存到文件:
doc.Save("books.xml");若只用XElement,可直接调用element.Save("file.xml"),会自动添加默认声明
加载和查询XML数据
用XDocument.Load()或XElement.Load()读取文件,再用LINQ语法筛选——这是LINQ to XML最强大的地方。
- 加载整个文档:
var doc = XDocument.Load("books.xml");只加载根元素:var root = XElement.Load("books.xml") - 查所有Book元素:
var books = doc.Root.Elements("Book") - 查id为"2"的Book:
var book = doc.Root.Elements("Book").FirstOrDefault(x => (string)x.Attribute("id") == "2") - 查所有标题含"C#"的Book:
var titles = doc.Descendants("Title").Where(t => t.Value.Contains("C#"))
修改和删除节点
所有操作都是就地修改,调用Save()才会持久化。注意属性和元素值的类型转换很灵活,常用(string)node或(int?)node安全取值。
- 修改属性:
book.SetAttributeValue("id", "5") - 修改元素内容:
book.Element("Title").Value = "C#高级编程" - 添加新子元素:
book.Add(new XElement("Price", "99.00")) - 删除某个子元素:
book.Element("Price")?.Remove()(加空条件避免异常) - 删除所有匹配元素:
doc.Root.Elements("Book").Where(b => (string)b.Attribute("status") == "deleted").Remove()
序列化简单对象为XML(轻量替代方案)
如果只是临时导出POCO对象,不用复杂映射,可用XElement配合对象初始化器快速生成:
- 假设有个
Book类,有Title和Author属性,可这样构造:new XElement("Book", new XElement("Title", book.Title), new XElement("Author", book.Author)) - 不建议对复杂对象用
XmlSerializer来回折腾,LINQ to XML写起来更可控,尤其需要定制标签名、忽略字段或动态结构时
基本上就这些。LINQ to XML没有学习曲线陷阱,关键记住:用XElement建结构、用Elements()/Descendants()找节点、用Where()/First()配合强转取值、改完记得Save()。不复杂但容易忽略细节,比如属性取值要加(string)、空元素检查要用?.Remove()。









