背景: win下的PHP文件打包,在Linux下解压后,在git status 时,显示发生修改,但并没有修改,查看文件会发现这种字符^M其实就是因为换行符的原因 ,Windows换行符和Linux换行符问题导致

方法一:(未生效)

去掉windows下的回车符 (注意^M 在linux 下写法 按^M 是回车换行符,输入方法是按住CTRL+v,松开v,按m)

sed -i ’s/^M//g’ df.txt

去掉windows下的回车符 (注意^M 在linux 下写法 按^M 是回车换行符,输入方法是按住CTRL+v,松开v,按m)

sed -e ’s/^M//g’ df.txt >cwm.txt

或者用

sed -e ’s/^M$//g’ df.txt >cwm.txt $代表行尾

方法二:(可行,Git diff 不显示文件修改,但git status 还是显示文件修改过,懵逼了,所以暂时放弃了,重新Git clone 拉去新的,把旧文件再拷贝进去,如果你有好的方法欢迎留言)

Linux和Windows和换行符不一样。Windows下是CRLF(\r\n或0d0a),Linux下是LF(\n或0a)。在Linux下有时会遇到从Windows过来的文本文件,这些文件带了Windows换行符,Linux下进行脚本处理时有可能会出一些莫名其妙的错误。因此需要将这些文件转换为Linux换行符。


之前都是用dos2unix命令转换,但是很多系统没装这个命令。百度一下,也有人用一个叫tofrodos的命令,但是我的系统上也没装这个命令。

但是,为一个小小的换行符转换何至于劳师动众安装什么软件。况且我的服务器与外网隔绝,安装软件不是一个简单的yum就可搞定的。


所以,我采用了Linux自带的sed命令完成相同的任务。


单个的文件装换

sed -i 's/\r//'  filename

批量的文件装换

sed -i 's/\r//'  filename1 filename2 ...

find conf/ -name "*.*" |xargs sed -i 's/\r//'


转换举例:

[root@zabbix ~]## echo -e 'a\n\r\b'>file1

[root@zabbix ~]## file file1

file1: ASCII text, with CR, LF line terminators, with overstriking

[root@zabbix ~]## sed -i 's/\r//'  filename

[root@zabbix ~]## file file1

file1: ASCII text, with overstriking

windows下回车换行符在Linux下显示^M问题_sed