linux 合并行常用方法

Linux 合并俩行为一行并用空格表示
sed -n '{N;s/\n/ /p}' aa.txt
aa aa
bb bb
awk 'BEGIN{FS="\n";ORS=""};{if($0 ~ /^10/ && NR>1){print "\n"$0;}else{print}}'
方法1:

sed -n 'p;n' test.txt #奇数行
sed -n 'n;p' test.txt #偶数行
方法2:

sed -n '1~2p' test.txt #奇数行
sed -n '2~2p' test.txt #偶数行
[james@zat2 scripts]$ sed '1~2N;s/\n/\t/' jishu.txt
bb dd
aa cc
[james@zat2 scripts]$ cat jishu.txt
bb
dd
aa
cc
[james@zat2 scripts]$ sed ':z ;N;s/\n/ / ; t z ;' jishu.txt
bb dd aa cc
sed默认只按行处理,N可以让其读入下一行,再对\n进行替换,这样就可以将两行并做一行。但是怎么将所有行并作一行呢?可以采用sed的跳转功能。:a 在代码开始处设置一个标记a,在代码执行到结尾处时利用跳转命令t a重新跳转到标号a处,重新执行代码,这样就可以递归的将所有行合并成一行。
[james@zat2 scripts]$ awk BEGIN{RS=EOF}'{gsub(/\n/," ");print}' jishu.txt
bb dd aa cc
说明:awk默认将记录分隔符(record separator即RS)设置为\n,此行代码将RS设置为EOF(文件结束),也就是把文件视为一个记录,然后通过gsub函数将\n替换成空格,最后输出。
[james@zat2 scripts]$ clear
[james@zat2 scripts]$ cat jishu.txt | xargs
bb dd aa cc

 

posted @ 2018-05-09 20:50  青青子衿zz  阅读(4390)  评论(0编辑  收藏  举报