XmlDocument 是 .NET 中基于 DOM 的 XML 操作类,支持从字符串、文件、URL 或 XmlReader 加载,可随机读写节点、XPath 查询,保存时需用 XmlWriter 设置缩进;注意内存占用、DTD 处理、命名空间及线程安全问题。

XmlDocument 是 .NET 中操作 XML 文档的核心类之一,属于 System.Xml 命名空间。它基于 DOM(文档对象模型),把整个 XML 加载到内存中,支持随机读写、节点增删改查、XPath 查询等。下面直接说怎么用它加载和保存 XML。
用 XmlDocument 加载 XML
有多种方式把 XML 数据加载进 XmlDocument 实例:
-
从字符串加载:用
LoadXml(string xml)方法,适合已知 XML 内容的场景。 -
从文件加载:用
Load(string filename)或Load(Stream),自动识别编码并解析文件。 -
从 URL 加载:用
Load(string url)(需网络可访问,注意安全限制)。 -
从 XmlReader 加载:用
Load(XmlReader),适合需要精细控制解析过程的情况(如跳过 DTD、设置验证选项)。
示例(从文件加载):
XmlDocument doc = new XmlDocument();
doc.Load("config.xml"); // 自动处理编码,如 UTF-8、UTF-16 等
修改 XML 内容
加载后,可通过 DocumentElement、SelectNodes()、GetElementsByTagName() 等方法定位节点,再调用 CreateElement、CreateTextNode、AppendChild、RemoveChild、SetAttribute 等进行修改。
常见操作:
- 查找节点:
XmlNode node = doc.SelectSingleNode("//user[@id='123']"); - 修改属性:
node.Attributes["status"].Value = "active"; - 添加子节点:
node.AppendChild(doc.CreateElement("role")).InnerText = "admin"; - 删除节点:
node.ParentNode.RemoveChild(node);
用 XmlDocument 保存 XML
保存分两种常用方式:
-
保存到文件:调用
Save(string filename),会以原始编码(或 UTF-8 默认)写入,保留格式但不自动缩进。 -
保存为格式化 XML(带缩进):需借助
XmlTextWriter或XmlWriter,设置Formatting.Indented。
示例(带缩进保存):
XmlWriterSettings settings = new XmlWriterSettings
{
Indent = true,
IndentChars = " ",
Encoding = Encoding.UTF8
};
using (XmlWriter writer = XmlWriter.Create("output.xml", settings))
{
doc.Save(writer);
}
注意事项
使用 XmlDocument 时要注意几点:
- 它是内存驻留型,大文件(如 >10MB)可能导致内存压力,此时建议改用
XmlReader/XmlWriter流式处理。 - 默认会加载 DTD 并尝试验证,若 XML 含外部 DTD 且网络不可达,可能抛异常;可用
XmlResolver = null禁用。 - 保存时不自动修正命名空间前缀,手动操作节点时注意
XmlNamespaceManager的配合(尤其用 XPath 查询时)。 - 线程不安全:XmlDocument 实例不能被多个线程同时读写,如需并发操作应加锁或改用线程安全替代方案(如
XDocument配合不可变操作)。










