[英]Awk - Adding specific number of spaces between columns
我的输入文件具有均匀分布的列,如下所示:
X a b C D
我如何使用awk指定列之间的空格数,以便得到如下内容:
X a b C D
我知道如何使用awk计算列之间的间隔,我只是不知道如何添加这些间隔以获取所需的布局。 有什么建议么?
与awk
$ echo "X a b C D" | awk '{printf "%-6s%-2s%-5s%-9s%s\n", $1,$2,$3,$4,$5}'
X a b C D
或直接与printf
$ echo "X a b C D" | xargs printf "%-6s%-2s%-5s%-9s%s\n"
X a b C D
这是printf派上用场的地方:
$ echo "X a b C D" | perl -lane 'printf "%-6s%-2s%-5s%-9s%s\n", @F'
X a b C D
根据需要调整字段宽度。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.