0

0

C# XDocument保存文件 XML缩进与格式化保存设置

星降

星降

发布时间:2026-02-12 11:01:26

|

532人浏览过

|

来源于php中文网

原创

XML保存无缩进是因XmlWriterSettings默认Indent=false,需显式设置Indent=true并传入XmlWriter;缩进、换行、编码、空白处理四者须协同一致。

c# xdocument保存文件 xml缩进与格式化保存设置

保存 XML 时没缩进?用 XmlWriterSettings 控制格式

默认用 XDocument.Save() 写文件,XML 是一行到底的——不是 bug,是默认关闭格式化的。真正起作用的是底层 XmlWriter 的设置,XDocument 自己不带“美化开关”。

必须显式构造 XmlWriter 并传入带缩进配置的 XmlWriterSettings

var settings = new XmlWriterSettings
{
    Indent = true,
    IndentChars = "  ",
    NewLineChars = "\n",
    NewLineHandling = NewLineHandling.Replace
};
using var writer = XmlWriter.Create("output.xml", settings);
doc.Save(writer);
  • Indent = true 是必要条件,不设这个,其他都白搭
  • IndentChars 建议用空格(" ""\t"),别用混合或中文全角空格
  • NewLineChars 设成 "\n" 更通用;Windows 默认 "\r\n",跨平台读写可能出空行异常
  • 别直接对 XDocument.ToString() 格式化后再写文件——它不保证格式稳定,且会丢弃原始声明编码

Save() 直接写文件 vs XmlWriter 手动写:行为差异在哪

调用 doc.Save("path.xml") 实际内部用了最简 XmlWriterSettingsIndent=false),相当于跳过了格式化逻辑。而手动传 XmlWriter,你完全掌控序列化过程。

  • 直接 Save(string) 无法指定编码(默认 UTF-8 无 BOM),但 XmlWriter.Create(Stream, settings) 可配合 StreamWriter 精确控制
  • 如果 XML 里有 (CR)或混合换行符,NewLineHandling = Replace 能统一归一化,否则缩进可能错位
  • 大文件慎用 ToString() + File.WriteAllText():会把整个树转成字符串再写,内存翻倍,还可能触发 OutOfMemoryException

中文内容乱码?检查 XmlWriterSettings.Encoding 和 BOM

即使设置了缩进,中文变问号或方块,大概率是编码没对齐。XML 声明里的 encoding="utf-8" 和实际字节流编码必须一致。

同程联盟景点门票动态程序 beta1.0
同程联盟景点门票动态程序 beta1.0

经过一段时间的开发,以及内部测试,同程网联盟景区新版程序正式发布推出,感谢广大联盟会员一直以来的支持与关注! 同程网联盟景区新版程序新功能介绍:1.统一的页面风格。页面风格将与随后推出的度假线路、酒店、机票以及融合版联盟程序风格保持一直;2.新增后台管理系统。可更加方便快捷的对网站进行个性化设置;3.动态与伪静态切换。后台操作,简单便捷;4.缓存管理。新增缓存,提高网站访问速度,后台可定期清理;5

下载
  • 不要依赖 XmlWriterSettings.Encoding = Encoding.UTF8 就万事大吉——.NET 6+ 默认 UTF-8 无 BOM,但某些老编辑器/系统认 BOM 才当 UTF-8
  • 真要兼容旧工具,得用 new UTF8Encoding(encoderShouldEmitUTF8Identifier: true) 构造编码对象再传入 XmlWriterSettings
  • 如果 XML 已含 ,但 Settings.Encoding 设了 UTF-8,保存后声明和内容编码就矛盾,解析器可能报 Invalid character in the given encoding

为什么 PreserveWhitespace = true 有时反而让缩进失效

XDocument 加载时若设了 PreserveWhitespace = true,会把原始空白字符(包括换行、缩进)当作文本节点保留。后续再保存,XmlWriter 的缩进逻辑会被这些“残留空白”干扰,导致嵌套层级错乱或空行爆炸。

  • 除非你明确需要保留用户手写的空格/换行(比如 XML 配置中内联的 SQL 或 JSON 片段),否则加载时别设 PreserveWhitespace = true
  • 已加载且开启了该选项的文档,可在保存前调用 doc.Descendants().Where(e => e.Nodes().All(n => n is XText t && string.IsNullOrWhiteSpace(t.Value))).Remove(); 清理冗余空白节点(谨慎使用,可能误删有意义的空文本)
  • 更稳妥的做法:加载时不用 PreserveWhitespace,靠 XmlWriterSettings 统一控制输出格式

缩进只是表象,真正要盯住的是三层一致性:加载时的空白策略、内存中节点结构的干净度、写出时 XmlWriterSettings 的编码与格式参数——漏掉任何一层,XML 文件看着就别扭。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

900

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

372

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1572

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

368

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1128

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

583

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

433

2024.04.29

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

189

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.2万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号