2

我正在使用 awk 对文件进行一些简单的计算,但无法正确输出格式。由于某种原因,OFS 仅适用于第一行(即仅在 BEGIN 块内),而对于其他行,在字段之间插入一个空格。

输入:

title   c1  c2  c3  n
AA  14  6   3   40
BB  8   2   2   38

单线:

cat file.txt | awk -F'\t' 'BEGIN {OFS="\t"; print "Title","Freq1","Freq2","Freq3","Total"}; NR>1{printf "%s %.3f %.3f %.3f %d\n", $1, $2/$5, $3/$5, $4/$5, $5;}' > file2.txt

我已经尝试从 BEGIN 中删除标题,但这并没有什么不同,BEGIN{FS="\t";OFS="\t";...}. 我在cygwin中使用awk。

4

1 回答 1

8

由于您正在使用,因此printf您正在积极地完全避免 OFS。如果你想合并 OFS,它会变得很丑:

NR>1 {printf "%s%s%.3f%s%.3f%s%.3f%s%d\n", $1, OFS, $2/$5, OFS, $3/$5, OFS, $4/$5, OFS, $5}

或者,不要使用 printf:

NR>1 {print $1, sprintf("%.3f",$2/$5), sprintf("%.3f",$3/$5), sprintf("%.3f",$4/$5), $5}
于 2013-06-12T09:55:22.773 回答