Summary:
This post explores the importance of line ending formats when working across platforms. It highlights the differences between Windows (CRLF) and Linux/Android (LF) line endings, explains common issues caused by mismatches, and introduces simple methods to convert files to the correct format. Whether you're editing configuration files for Linux or deploying scripts on Android, understanding line endings is essential for seamless compatibility.
由于windows/dos默认的换行符与linux/unix不一样, 在 Windows 常用的编辑器上编辑,部署到 Linux 中的 config.json
或 shell
脚本文件,或者各种配置文件,都应使用 LF 换行格式,否则可能导致解析错误。此外, 有些电子设备通过串口发控制码时也有类似问题, 有不少串口调试工具发送对应代码的方式也大不相同
操作系统 | 换行符 | 符号表示 |
---|---|---|
Linux / Unix | LF | \n |
macOS / iOS | LF | \n |
Windows | CR+LF | \r\n |
旧版 Mac OS(pre-OS X) | CR | \r |
在安卓系统中,配置文件(如 .json
, .conf
, .ini
等)推荐使用 Linux 格式的换行符,即 LF(Line Feed, \n
),因为:
✅ 安卓是基于 Linux 内核
安卓系统本质上是一个裁剪版的 Linux,底层文件系统和工具链都遵循 Linux 规范。
因此,安卓上的大多数应用程序和命令行工具(如 Termux、BusyBox、init 脚本)默认识别 LF 换行符。
⚠️ 使用 Windows 格式(CRLF, \r\n
)可能导致的问题:
问题 | 说明 |
---|---|
脚本执行失败 | Shell 脚本或配置被解释器误判为错误语法。 |
JSON/配置文件无法解析 | 某些程序或工具会报错 unexpected character '\r' 。 |
grep/sed/awk 匹配失败 |
文本工具处理换行敏感。 |
✅ 如何确保使用 LF 换行
在 Windows 上编辑时:
使用支持设置换行格式的编辑器,如 VS Code、Notepad++。
VS Code:
右下角点击
CRLF
→ 选择LF
或在保存时自动设置:
// settings.json "files.eol": "\n"
Notepad++:
菜单栏 →
Edit
→EOL Conversion
→Unix (LF)
在 Linux / Termux 中查看或转换:
查看文件格式:
file config.json
输出包含
with CRLF line terminators
表示是 Windows 格式转换为 LF:
dos2unix config.json
✅ 总结
安卓配置文件应使用 LF(Linux 换行符)
避免使用 CRLF(Windows 换行符)
推荐使用
dos2unix
、sed
、或文本编辑器转换特别注意 脚本、配置文件、JSON 文件,不规范换行会导致启动失败或解析错误
如需我帮你检测某个配置文件是否是 CRLF,可以发我内容或文件。
在 windows上, 可以用免费软件Visual Studio Code(VS Code) 来编辑linux配置文件,可以非常方便地将配置文件保存为 Linux 格式的换行符(LF),步骤如下:
✅ 方法一:使用 VS Code 状态栏切换换行符格式
打开配置文件(如
config.json
)。在 VS Code 窗口右下角,会看到一个显示为:
CRLF
(表示 Windows 格式)或
LF
(表示 Linux 格式)
点击那个
CRLF
字样。会弹出一个选择菜单,点击
LF
(即 Unix 格式换行符)。然后点击顶部菜单或快捷键保存文件:
File → Save 或按Ctrl + S
。
✅ 方法二:全局默认设置为 Linux 换行符
如果希望之后创建的新文件都默认使用 Linux 格式:
打开 VS Code 设置(快捷键:
Ctrl + ,
)。搜索:
eol
。找到设置项:
Files: Eol
从下拉菜单中选择:
\n (LF)
保存设置即可。
🔧 终端验证换行格式(可选)
如果你在 Linux 下想确认某文件是否使用 LF 换行,可运行:
file config.json
返回结果中包含 with CRLF line terminators
就是 Windows 格式,
包含 with LF line terminators
就是 Linux 格式。
在 Linux 下,将 Windows 格式(CRLF) 的换行符转换为 Linux 格式(LF),可以使用以下几种命令行工具:
✅ 推荐命令:dos2unix
dos2unix 文件名
🔹 安装(如果未安装):
Debian/Ubuntu 系:
sudo apt install dos2unix
✅ 替代方案:使用 sed
sed -i 's/\r$//' yourfile
说明:
\r
是回车符(CR),Windows 格式的换行是\r\n
该命令把所有行尾的
\r
去除,留下\n
✅ 也可以用 awk
awk '{ sub(/\r$/, ""); print }' yourfile > newfile
✅ 或者用 tr
tr -d '\r' < yourfile > newfile
总结
工具 | 特点 |
---|---|
dos2unix |
简洁、专用,推荐 |
sed |
通用,不依赖额外工具 |
awk /tr |
同样可行,用于管道处理等 |
建议: 批量转换多个文件可用脚本批处理,例如:
find . -type f -name "*.json" -exec dos2unix {} \;