将 Pandoc 管道数据与 AWK 结合使用

将 Pandoc 管道数据与 AWK 结合使用

数据

ID     | Size      | Blocks
-------|-----------|---------
206  |80760288   | 157744 
207  |80760288   | 157744
328  |241520288  | 471728

AWK 想要的输出

ID     |BlockSize | Size      | Blocks
-------|----------|-----------|---------
206  | 511.971  |80760288   | 157744 
207  | 511.971  |80760288   | 157744
328  | 511.991  |241520288  | 471728

其中blockSize是大小/块。

如何使用 AWK 进行这种转换?

答案1

这是一种方法:

$ awk -F'|' -vOFS="|" '{
    if(NR==1){print $1," Blocksize ",$2,$3}
    else if(NR==2){print $1,"-----------",$2,$3}
    else{printf "%-7s|%-11s|%-11s|%-11s\n",$1,$2/$3,$2,$3}
}' file
ID     | Blocksize | Size      | Blocks
-------|-----------|-----------|---------
206    |511.971    |80760288   | 157744    
207    |511.971    |80760288   | 157744    
328    |511.991    |241520288  | 471728    

然而,由于需要保持列对齐,这变得不必要的复杂。因为我怀疑您并不真正需要它,所以您可能只想使用它:

$ sed 's/[-|]/ /g;/^ *$/d' file | 
   awk '{if(NR==1){print $1,"Blocksize",$2,$3}else{print $1,$2/$3,$2,$3}}'
ID Blocksize Size Blocks
206 511.971 80760288 157744
207 511.971 80760288 157744
328 511.991 241520288 471728

虽然这稍微不太人性化,但对于任何需要空格分隔数据的程序来说,它都是完美的输入。

相关内容