Python文本读写换行符处理核心是open()的newline参数与文件模式配合:文本模式默认启用通用换行符支持,读时统一转\n、写时转系统默认;设newline=""可禁用转换;二进制模式完全不处理;print()自动加\n而write()需手动添加。
Python 文本读写时换行符的处理,核心在于 open() 的 newline 参数 和 文件打开模式(text vs binary) 的配合。默认情况下 Python 会自动转换换行符,但具体行为取决于平台、模式和参数设置。
以文本模式(如 "r"、"w")打开文件时,Python 默认启用“通用换行符支持”:
\r\n(Windows)、\r(旧 Mac)、\n(Unix/Linux/macOS)都会被统一转为 \n;\n 会被自动转换为当前操作系统的默认换行符(如 Windows 
\r\n,Linux 写为 \n);newline 参数控制,默认值为 None,即启用自动转换。若需**完全禁用换行符转换**(例如处理混合换行符的配置文件、保留原始格式),应显式指定 newline="":
\r\n 不变,不会转成 \n);\n 不再被转义,直接写入字节 b'\n';newline="" 仅在文本模式下合法,且必须与 encoding 同时使用(不能用于二进制模式)。用 "rb" 或 "wb" 打开文件时,Python 完全不干预换行符:
bytes,内容与文件字节完全一致;bytes 也原样落盘,无任何转换;常见误区是混用 print() 和 .write() 导致空行增多:
print("line", file=f) 默认末尾加 \n(可设 end="" 关闭);f.write("line\n") 需手动添加换行符,否则不换行;write("line\n"),再调用 print(file=f) 就会多出一个空行。