与awk的俏丽的打印桌

tar*_*sch 7 formatting awk tabular

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

> field1 field2 field3 field4    
> 11.79     7.87    11.79    68   
> .. more numbers
Run Code Online (Sandbox Code Playgroud)

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

> field1    field2  field3   field4       
> 11.79     7.87    11.79    68
> .. more numbers
Run Code Online (Sandbox Code Playgroud)

我的生成脚本如下所示: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); '
Run Code Online (Sandbox Code Playgroud)

如果可以的话,我真的想避免使用ascii格式化echo命令.

Pri*_*ley 23

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

使用column.

手册页中的示例:

   (printf "PERM LINKS OWNER GROUP SIZE MONTH DAY HH:MM/YEAR NAME\n" \
   ; ls -l | sed 1d) | column -t
Run Code Online (Sandbox Code Playgroud)


Fre*_*ihl 15

这个单行怎么样:

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
Run Code Online (Sandbox Code Playgroud)

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

  • @FelipeAlvarez - 发布一个新问题.但是你可以对数据进行双次传递.第一遍你计算最大宽度,第二遍你用第一遍的宽度打印数据.第三种选择是使用足够大的宽度.第四个是生成一个csv文件而是在例如电子表格或使用python和csv-module等中使用它.另外,看一下`column`程序.做一个^人专栏 (2认同)