由于在shell处理了windows里的字符文件,导致本该输出成两行的字符串变成了一行,而第一行行首的一些字符被第二行覆盖了

这是由于windows和linux下的/r ^M 字符的区别导致,可以将异常字符都筛选掉再进行输出:如sed 's/[^0-9,.:A-Za-z]//g'把不符合规则的字符过滤掉

转载了下面的可以参考下:

Unix体系里,每行结尾只有“<换行>”,即“\n”;Windows体系里面,每行结尾是“<换行><回 车>”,即“\n\r”。一个直接结果是,Unix体系下的文件在Windows里打开的话,所有文字会变成一行;而Windows里的文件在Unix下打开的话,在每行的结尾可能会多出一个^M符号。


 


好了,所以我的题目就出在被处理惩罚的文件的每行末尾都有^M符号,而这凡是是看不出来的。可以用"cat -A test.file"号令查看。是以当我想在行尾添加字符的时辰,它老是添加在行首且会覆盖掉本来行首的字符。


要把文件转换一下,有两种办法:


1.号令dos2unix test.file


2.去掉"\r" ,用号令sed -i ""s/\r//"" test.file


好了,如许处理惩罚完,就OK啦!!!