awk 将多行文件转为一行

现在有这么一个文件,可以看到输出了该 yml 文件中的md 文件后缀的内容

➜  netease-techs cat mkdocs.yml| awk -F ':' '{print $2}' | grep moduls| awk -F '/' '{print $2}'
nvm.md
cdn.md
rds.md
nos.md
nce.md
redis.md
elk.md
memcached.md
kafka.md
rabbitmq.md
haproxy.md
disk.md
vpc.md
nas.md
domain.md
mongodb.md
acservices.md
logserivces.md
amservices.md
alarm.md

然后我希望将这很多行转为一行输出

➜  netease-techs cat mkdocs.yml| awk -F ':' '{print $2}' | grep moduls| awk -F '/' '{print $2}' | awk BEGIN{RS=EOF}'{gsub(/\n/," ");print}'
nvm.md cdn.md rds.md nos.md nce.md redis.md elk.md memcached.md kafka.md rabbitmq.md haproxy.md disk.md vpc.md nas.md domain.md mongodb.md acservices.md logserivces.md amservices.md alarm.md

说明:awk默认将记录分隔符(record separator即RS)设置为\n,此行代码将RS设置为EOF(文件结束),也就是把文件视为一个记录,然后通过gsub函数将\n替换成空格,最后输出。

另外利用 xargs 也许是最方便的了

➜  netease-techs cat mkdocs.yml| awk -F ':' '{print $2}' | grep moduls| awk -F '/' '{print $2}' | xargs
nvm.md cdn.md rds.md nos.md nce.md redis.md elk.md memcached.md kafka.md rabbitmq.md haproxy.md disk.md vpc.md nas.md domain.md mongodb.md acservices.md logserivces.md amservices.md alarm.md

创建文件

➜  netease-techs cat mkdocs.yml| awk -F ':' '{print $2}' | grep moduls| awk -F '/' '{print $2}' | xargs touch
➜  netease-techs ls
acservices.md  cdn.md         domain.md      kafka.md       mkdocs.yml     nce.md         rabbitmq.md    vpc.md
alarm.md       disk.md        elk.md         logserivces.md mongodb.md     nos.md         rds.md
amservices.md  docs           haproxy.md     memcached.md   nas.md         nvm.md         redis.md
➜  netease-techs