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