linux 合并行常用方法

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

原文地址:https://www.cnblogs.com/zhanzhan/p/9016550.html