9

我有一些文本文件,如下所示。我想减去第 2 列和第 4 列的值,并且需要为输出创建一个新列。

co1  co2   co3    co4

r1  15.2  13.0   21.4
r2  23    15     15.7
r3  14    8      12

期望的输出

co1  co2   co3   co4   diff.    

r1  15.2  13.0   21.4   -6.2
r2  23    15     15.7   7.3
r3  14    8      12     2
4

3 回答 3

14

注意:您可以将 awk 命令全部放在一行上,但这更整洁(如果需要,更透明且更易于修改)。

这个so.awk脚本:

NR==1{print $0, "   diff.\n"}
NR>2{printf("%s\t%5.1f\n", $0, $2-$4)}

给出:

co1  co2   co3   co4     diff.

r1  15.2  13.0   21.4    -6.2
r2  23    15     15.7     7.3
r3  14    8      12       2.0

鉴于文件中的数据data.txt发出此命令:

 awk -f so.awk data.txt

(您可能需要调整格式以满足您的确切需求)

于 2012-08-17T11:46:45.513 回答
10

这个单线工作:

awk 'NR == 1 { $5 = "diff." } NR >= 3 { $5 = $2 - $4 } 1' <input.txt

它给:

co1 co2 co3 co4 diff.

r1 15.2 13.0 21.4 -6.2
r2 23 15 15.7 7.3
r3 14 8 12 2

如果您想按选项卡分隔字段,这就是您想要的:

awk 'BEGIN { OFS = "\t" } NR == 1 { $5 = "diff." } NR >= 3 { $5 = $2 - $4 } 1' <input.txt
于 2012-08-17T12:08:56.777 回答
8

如果您没有标题,则可以简化 Taku Miyakawa 的单行:

awk '{ $5 = $2 - $4 } 1' input.txt > inputdiff.txt

或使用制表符分隔:

awk 'BEGIN { OFS = "\t" } { $5 = $2 - $4 } 1' input.txt > inputdiff.txt
于 2014-10-24T14:41:03.410 回答