参考:https://blog.csdn.net/lovelovelovelovelo/article/details/79239068
unix体系中,换行符为"\n",而win体系中,换行符为"\n\r"。这种差异导致,win当中的文本文件在linux中打开,在每行结尾会多出一个^M符号(直接看不出来的使用cat -A xxx.txt查看),而linux当中的文本文件在win当中打开的话,所有文字变为一行。
如何去除win中txt拷贝到unix下每行后面出现的^M?
法一:使用vim打开文本文件,在命令模式下输入:%s/^M$//g
其中,%指匹配整个文件,s是置换的意思,^M后面的$代表匹配行尾的内容,g表示每行中匹配到的内容都要置换。比如,将某个文件中的Vim全部替换为VIM,可以使用:%s/Vim/VIM/g。(测试失败,可以替换常规字符,^M输入有问题)
法二:使用vim打开文本文件,在命令模式下输入:set fileformat=unix,保存退出即可。(测试通过)
法三:使用sed工具,sed 's/^M//' xxx.txt > xxx.txt(测试失败,可以替换常规字符)
法四:直接删除'\r',tr -d '\r'(测试失败)
法五:dos2unix xxx.txt(测试失败,可能需要安装某些依赖包)