sed:空格 转换为 , 命令:sed 's/ /,/g' 需转换文件名 > 结果文件名
删除文件中所有换行符:
我们总会习惯使用下面命令来操作,但是会发现没有效果,这是因为sed的操作单位就是行
sed -i 's/\\n//g' file
正确的做法是如下这样
sed -i ':a;N;$!ba;s/\n/;/g' file
如果是每两行删除换行符,可以执行下面语句
sed -i 'N;s/\\n/:/' curr_head
如果是操作换行符
sed将换行符替换掉,使用sed "s/\n//g" file 无法实现
上网查了下,使用
sed ":a;N;s/\n//g;ta" file
或者
sed ":a;N;s/\n//g;ba" file
:a和ta是配套使用,实现跳转功能。t是test测试的意思。
:a和ba的配套使用方式,也可以实现跳转功能。b是branch分支的意思。
branch循环到文本结束。比如sed ":a;N;s/\n//g;ba" a.txt,转换成自然语言的描述,就是
while(1) {
N;
s/\n//g;
}
test可以根据替换命令的完成是否成功,决定是否跳转。比如sed ":a;N;s/\n//g;ta" a.txt,转换成自然语言的描述,就是
while(state == 1) { #注释:默认state就当是1好了。
N;
s/\n//g; #注释:成功,返回state为1;否则返回state=0。此state用于跳转判断。
}
else {
last; #注释:即退出循环语句。
}
第一种方法:使用test跳转命令,实现替换换行符
sed ":a;N;s/\n//g;ta" file
N是把下一行加入到当前的hold space模式空间里,使之进行后续处理,最后sed会默认打印hold space模式空间里的内容。也就是说,sed是可以处理多行数据的。
第二种方法:使用branch跳转命令,实现替换换行符
~$ sed ":a;N;s/\n//g;$!ba" file
增加$!ba语句,$的意思是最后一行,不跳转到标记a处,即退出命令循环。
同理,也可以用下述命令。
~$ sed ":a;$!N;s/\n//g;ba" file
转载 linux sed命令,如何替换换行符“\n”_学而不思则罔,思而不学则殆-CSDN博客_sed 替换换行符
如何替换\n也就是把所有的行都归为一行
第一种方式
[root@localhost ~]# sed ':a;N;$!ba;s/\n/ /g' file.txt
第二种方式
[root@localhost ~]# tr "\n" " " < file.txt