使用XmlDocument或XDocument配合XmlWriterSettings可精确控制XML的格式与编码。1. 通过设置Indent=true、Encoding=new UTF8Encoding(false)和NewLineChars="\n",确保缩进、无BOM的UTF-8编码及LF换行。2. 修改节点后,必须使用XmlWriter保存以保留格式。3. XDocument默认良好格式化,但自定义编码仍需XmlWriter。4. 验证输出时检查声明编码、内容正确性及文件实际格式,避免因BOM或CRLF导致兼容问题。关键是在保存时始终显式配置XmlWriterSettings以统一输出标准。

在C#中解析、修改并保存XML时,确保格式和编码的正确性需要关注XML文档的声明、缩进、字符编码以及写入方式。使用 XmlDocument 或 XDocument 配合正确的设置可以有效控制输出质量。
XmlDocument 支持保留原始格式,并可通过 XmlWriter 精确控制输出。关键在于设置 XmlWriterSettings:
Indent = true 实现良好缩进Encoding(如 UTF-8)避免乱码CloseOutput = true 确保流正确关闭示例代码:
XmlDocument doc = new XmlDocument();
doc.Load("input.xml");
// 修改内容
XmlNode node = doc.SelectSingleNode("//name");
if (node != null)
node.InnerText = "张三";
// 使用 XmlWriter 保存,控制格式与编码
XmlWriterSettings settings = new XmlWriterSettings
{
Indent = true,
IndentChars = " ",
Encoding = new UTF8Encoding(false), // 不带 BOM 的 UTF-8
NewLineChars = "\n"
};
using (XmlWriter writer = XmlWriter.Create("output.xml", settings))
{
doc.Save(writer);
}
XDocument 默认输出会自动格式化,但编码控制需依赖 Save 方法中的 XmlWriter:
doc.Save(path) 会使用 UTF-8(无 BOM)并自动缩进示例:
XDocument doc = XDocument.Load("input.xml");
doc.Root?.Element("name")?.SetValue("李四");
// 自定义编码输出
using (var writer = XmlWriter.Create("output.xml", new XmlWriterSettings
{
Indent = true,
Encoding = Encoding.UTF8
}))
{
doc.Save(writer);
}
Windows 下常因 BOM 或换行符导致兼容性问题:
new UTF8Encoding(false) 可避免生成 BOMNewLineChars = "\n" 统一为 LF,避免 Windows 的 CRLF 影响脚本处理建议在保存后重新加载文件验证:
例如:
// 验证保存结果
XDocument test = XDocument.Load("output.xml");
Console.WriteLine(test.Declaration?.Encoding); // 应为 utf-8
以上就是C#解析并修改XML后保存 如何确保格式与编码的正确性的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号