我正在使用awk对文件进行一些简单的计算,但无法正确获得输出格式。 OFS由于某种原因仅应用于第一行(即仅在BEGIN块内),而对于其他行,在字段之间插入单个空格。
输入:
title c1 c2 c3 n
AA 14 6 3 40
BB 8 2 2 38
Oneliner:
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。
答案 0 :(得分: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}