Python中表示换行的符号只有\n,它是字符串层面唯一的逻辑换行符;\r\n和\r仅在I/O层或历史系统中出现,Python通过文本模式自动转换,但字符串本身只识别\n。

Python 中表示换行的符号只有 \n,它在所有主流操作系统(Windows/macOS/Linux)中都有效,且是唯一被 Python 字符串字面量和标准库统一识别的换行符。
为什么不是 \r\n 或 \r?
虽然 Windows 文件传统用 \r\n、旧 Mac 用 \r,但 Python 在字符串层面只把 \n 视为换行控制符:
-
\n是 Python 的“逻辑换行符”,print()、str.splitlines()、textwrap等都按它切分或渲染 -
\r\n在字符串里只是两个字符:\r(回车)+\n(换行),不会自动合并成一个语义单位 - 写入文件时,若以文本模式(默认)打开,Python 会根据系统自动将
\n转为本地换行序列(如 Windows 下转成\r\n);但这是 I/O 层的透明转换,不是字符串本身的特性
\n 在不同上下文的行为差异
同一个 \n,在打印、写入、读取、正则匹配中表现不完全一致:
- 用
print("a\nb")输出,终端看到两行——因为print默认末尾加\n,且终端解释\n为换行 - 用
open("f.txt", "w").write("a\nb"),实际写入内容取决于打开模式:"w"(文本模式)会按平台转义;"wb"(二进制模式)则原样写入\n字节 -
"a\nb".split("\n")得["a", "b"];但"a\r\nb".split("\n")得["a\r", "b"]——说明\r不会被自动剥离 -
re.findall(r".+", "a\nb", re.DOTALL)匹配到["a", "b"],因为.默认不匹配\n;加re.DOTALL后才跨行匹配
读取文件时换行符的兼容性处理
从外部读入的文本可能含混合换行符(\n、\r\n、\r),不能假设全是 \n:
立即学习“Python免费学习笔记(深入)”;
- 推荐用
str.splitlines(keepends=False):它能识别所有常见换行符并统一拆分,且不保留换行符本身 - 避免用
.replace("\r\n", "\n").replace("\r", "\n")手动归一化——容易误伤内容里的孤立\r - 若需保留原始换行符样式(如编辑器场景),可用
open(..., newline="")禁用通用换行符转换,再自行解析
text = "line1\r\nline2\nline3\r" lines = text.splitlines() # → ["line1", "line2", "line3"]
真正容易出问题的地方,是把换行符当成“平台相关的东西”去硬编码判断,或者在二进制/文本模式混用时忽略 Python 的自动转换逻辑。记住:字符串里只认 \n,I/O 时才谈转换。其他符号都是干扰项。










