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()。
