
Go 使用 \n 写入文件时,在 Windows 记事本中无法正确显示换行,因其仅识别 \r\n(CRLF)作为行结束符;需显式使用 \r\n 或通过 fmt.Fprintln / bufio.Writer 等更健壮的方式处理跨平台换行。
go 使用 `\n` 写入文件时,在 windows 记事本中无法正确显示换行,因其仅识别 `\r\n`(crlf)作为行结束符;需显式使用 `\r\n` 或通过 `fmt.fprintln` / `bufio.writer` 等更健壮的方式处理跨平台换行。
在 Go 中向文本文件写入内容时,若期望在 Windows 系统的记事本(Notepad.exe)中正常显示多行,仅使用 \n(LF,Line Feed)是不够的。这是因为 Windows 传统上采用 \r\n(CR+LF,Carriage Return + Line Feed)作为标准行结束序列,而记事本严格依赖该序列识别换行——相比之下,WordPad、VS Code、Sublime Text 等现代编辑器能智能识别 \n 或 \r\n,因此显示正常。
最直接的修复方式是将字符串中的 \n 替换为 \r\n:
n, err := io.WriteString(f, "Hello World\r\n")
if err != nil {
log.Fatal(err)
}
n, err = io.WriteString(f, "Goodbye\r\n")
if err != nil {
log.Fatal(err)
}✅ 此写法可确保记事本逐行显示:
Hello World Goodbye
⚠️ 注意事项:
- 不要手动拼接 \r\n 后再调用 io.WriteString 多次写入未换行内容(如 "Hello World\r\nGoodbye\r\n"),否则逻辑仍正确,但可读性与维护性下降;
- 更推荐使用 fmt.Fprintln,它自动追加平台感知的换行符(底层调用 runtime.GOOS 判断):
fmt.Fprintln(f, "Hello World") // 自动写入 "\r\n"(Windows)或 "\n"(Linux/macOS) fmt.Fprintln(f, "Goodbye")
- 若需高性能批量写入(如日志、大数据导出),建议搭配 bufio.NewWriter 使用,并在关闭前调用 Flush():
w := bufio.NewWriter(f) fmt.Fprintln(w, "Hello World") fmt.Fprintln(w, "Goodbye") if err := w.Flush(); err != nil { log.Fatal(err) }
? 总结:跨平台文本输出应避免硬编码 \n;优先使用 fmt.Fprintln 或 bufio.Writer 实现可移植换行;仅在需精确控制格式(如生成 Windows INI 文件、HTTP 响应头)时显式使用 \r\n。同时注意:os.Create 返回的文件句柄需显式 f.Close()(或使用 defer f.Close()),否则可能丢失最后写入内容。










