LINUX删掉换行符

LINUX删掉换行符,第1张

去掉文件中的换行符

(1)tr命令的 *** 作是针对文件的 *** 作,它把整个文本当做 *** 作的对象,所以可以直接去除文件中的换行符

tr '\n' ' ' <file

(2)sed的 *** 作对象是行.而作为行分割符号的回车符,本身是不属于行的.所以sed中必须加上N命令,把下一行的内容添加到当前的pattern space中,这样实际上是把相邻的2行合并了.下一次仍然是先n,再p,再N,开始新的轮回:

cat file | sed 'Ns/\n/ /'

所以上面的语句是不能把文件内容合并为一行的,到底该怎么写,我暂时没有想到,呵呵

(3)直接用awk

awk '{printf("%s ",$0)}' file

(4)当然,用echo也是可以的:

while read linedo echo -n "$line"done <awk_help.txt, 这样,可以把awk_help.txt的内容合并为一行

sed -e "s#\[/r][/r][/n]#\[/r][/n]#g" file

在windows上编写的shell、python等脚本在Linux上无法正常的执行,会有 ^M 相关提示,

原因 :

在Linux上使用vim打开文件,显示很多的 ^M 字符,主要是因为在Windows下换行使用CRLF两个字符来表示,其中CR为回车(ASCII=0x0D),LF为换行(ASCII=0x0A),而在Linux下使用LF一个字符来表示。在Linux下使用vim来查看一些Windows下创建的脚本文件时,会发现在每一行尾部有^M字符,其实它是显示CR回车字符

Unix体系里,每行结尾只有“<换行>”,即“\n”;

Windows体系里面,每行结尾是“<换行><回 车>”,即“\n\r”。

一个直接结果是,Unix体系下的文件在Windows里打开的话,所有文字会变成一行;

而Windows里的文件在Unix下打开的话,在每行的结尾可能会多出一个^M符号。

如果正常编辑文件中看不见^M,可以用”cat -A test.file”号令查看。

使用vim方式处理

在vim命令模式下输入%s/^M$//g

回车即会自动删除该文件中的所有 ^M 字符。

% 指匹配整个文件,s 是置换的意思,^M 注意要用 Ctrl + V Ctrl + M 来输入,M 后面的 $ 代表匹配行尾的内容,最后的 g 则表示每行中匹配到的内容都要置换。

理解了命令的含义,就好变通使用了,比如说,要将某个文件中的 Vim 全部替换成 VIM,则可以使用这样的命令::%s/Vim/VIM/g。

方法1:

在命令模式下:输入:%s/^M//g 然后,回车即可替换

注,其中”^M”的输入,分别是“Ctrl+v”、“Ctrl+M”键生成的

方法2:

使用vi打开文本文件

vi dos.txt

命令模式下输入

:set fileformat=unix

:w

方法3:

使用sed 工具

sed ’s/^M//’ filename >tmp_filename

方法4:

既然window下的回车符多了‘\r’,那么当然通过删除‘\r’ ,也可以实现:

tr -d ‘\r’

方法5:使用Linux上的工具

tofrodos

(1)安装tofrodos

sudo apt-get install tofrodos

实际上它安装了两个工具:todos(相当于unix2dos),和fromdos(相当于dos2unix)

安装完即可,现在你已经可以进行文本格式的转换啦。

比如: todos Hello.txt (即unix2dos Hello.txt)

fromdos Hello.txt (即dos2unix Hello.txt)

PS :

编辑器IDE设置文件回车格式为unix格式

tmp = $(command)

echo "$tmp" 这里的$tmp必须加上双引号,否则除最后一行之外的其他行的换行符都会变成空格! (估计linux源码就是这么设计的,反正shell里面的现象就是这样的,我也不知道为什么)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7416115.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存