Chinaunix
标题:
取最大值。
[打印本页]
作者:
nb509
时间:
2012-07-12 10:53
标题:
取最大值。
1 a_130786 1766
2 a_000014 4678
9 a_000662 1815
9 a_001160179 2025
9 a_001160170 2349
9 a_001160171 2199
9 a_001160172 2120
9 a_001160173 1965
9 a_001160174 2038
9 a_001160175 2083
9 a_001160176 1933
10 a_000015 1317
12 a_001085 1629
13 a_001086 1725
14 a_001087 1859
15 a_001088 1048
15 a_001166579 1935
16 a_001605 3344
18 a_001127448 4908
18 a_020686 4814
18 a_000663 5586
19 a_005502 10515
20 a_212533 8163
20 a_001606 8171
复制代码
比如第1列的“9”对应第3列不同的数字,怎么把第3列的数字,替换成这几个数字中的最大值。其他类似。如果第1列只对应第3列的一个值,就不变。第1列对应第3列多个数字,就取最大值。
最后结果变成这样:
1 a_130786 1766
2 a_000014 4678
9 a_000662 2349
9 a_001160179 2349
9 a_001160170 2349
9 a_001160171 2349
9 a_001160172 2349
9 a_001160173 2349
9 a_001160174 2349
9 a_001160175 2349
9 a_001160176 2349
10 a_000015 1317
12 a_001085 1629
13 a_001086 1725
14 a_001087 1859
15 a_001088 1935
15 a_001166579 1935
16 a_001605 3344
18 a_001127448 5586
18 a_020686 5586
18 a_000663 5586
19 a_005502 10515
20 a_212533 8171
20 a_001606 8171
复制代码
作者:
personball
时间:
2012-07-12 10:59
回复
1#
nb509
personball@vostro:ttt$awk 'NR==FNR&&($3>a[$1]){a[$1]=$3} NR>FNR{$3=a[$1];print $0}' file file
1 a_130786 1766
2 a_000014 4678
9 a_000662 2349
9 a_001160179 2349
9 a_001160170 2349
9 a_001160171 2349
9 a_001160172 2349
9 a_001160173 2349
9 a_001160174 2349
9 a_001160175 2349
9 a_001160176 2349
10 a_000015 1317
12 a_001085 1629
13 a_001086 1725
14 a_001087 1859
15 a_001088 1935
15 a_001166579 1935
16 a_001605 3344
18 a_001127448 5586
18 a_020686 5586
18 a_000663 5586
19 a_005502 10515
20 a_212533 8171
20 a_001606 8171
personball@vostro:ttt$
复制代码
作者:
nb509
时间:
2012-07-12 11:00
先排序一下,应该好处理一点。
sort -k 1,1n -k 3,3nr
作者:
nb509
时间:
2012-07-12 11:06
回复
2#
personball
为什么我跑出来的结果文件是空的???
作者:
jiejie455
时间:
2012-07-12 11:07
awk 'NR==FNR{a[$1]=(a[$1]<$3)?$3:a[$1]};NR>FNR{print $1"\t"$2"\t"a[$1]}' data data
复制代码
作者:
nb509
时间:
2012-07-12 11:34
多谢两位。
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2