11

我想打印一个如下所示的表格:

> field1 field2 field3 field4    
> 11.79     7.87    11.79    68   
> .. more numbers

如何安排列的标题以将它们放在相应列顶部的方式排列?

> field1    field2  field3   field4       
> 11.79     7.87    11.79    68
> .. more numbers

我的生成脚本如下所示:capture.sh:

  echo 'field1, field2, field3, field4'
  awk '/Capture the tablestuff/{set variables}
  /DONE/ { printf("%5d %8.2f %8.2f %8.2f \n" ,field1, field2, field3, filed4); '

如果可以的话,我真的很想避免对 echo 命令进行 ascii 格式设置。

4

2 回答 2

32

我如何安排列的标题以将它们放在相应列顶部的方式排列?

使用column.

手册页中的示例:

   (printf "PERM LINKS OWNER GROUP SIZE MONTH DAY HH:MM/YEAR NAME\n" \
   ; ls -l | sed 1d) | column -t
于 2011-06-07T09:06:49.320 回答
24

这个单线怎么样:

awk 'BEGIN {printf("%s %8s %8s %8s \n" ,"field1", "field2", "field3", "field4")}
{printf("%6.2f %8.2f %8.2f %8.2f\n", $1, $2, $3, $4)}' input

field1   field2   field3   field4 
 11.79     7.87    11.79    68.00
 11.79     7.87    11.79    68.00
 11.79     7.87    11.79    68.00
 11.79     7.87    11.79    68.00

BEGIN用于打印标题,然后打印根据printf格式化的每一行,以及input文件中的所有数字,这里假设每行4个,没有别的。根据您的需要调整它...

于 2011-06-07T09:07:50.520 回答