Chinaunix

标题: 取最大值。 [打印本页]

作者: nb509    时间: 2012-07-12 10:53
标题: 取最大值。
  1. 1        a_130786        1766
  2. 2        a_000014        4678
  3. 9        a_000662        1815
  4. 9        a_001160179        2025
  5. 9        a_001160170        2349
  6. 9        a_001160171        2199
  7. 9        a_001160172        2120
  8. 9        a_001160173        1965
  9. 9        a_001160174        2038
  10. 9        a_001160175        2083
  11. 9        a_001160176        1933
  12. 10        a_000015        1317
  13. 12        a_001085        1629
  14. 13        a_001086        1725
  15. 14        a_001087        1859
  16. 15        a_001088        1048
  17. 15        a_001166579        1935
  18. 16        a_001605        3344
  19. 18        a_001127448        4908
  20. 18        a_020686        4814
  21. 18        a_000663        5586
  22. 19        a_005502        10515
  23. 20        a_212533        8163
  24. 20        a_001606        8171
复制代码
比如第1列的“9”对应第3列不同的数字,怎么把第3列的数字,替换成这几个数字中的最大值。其他类似。如果第1列只对应第3列的一个值,就不变。第1列对应第3列多个数字,就取最大值。
最后结果变成这样:
  1. 1        a_130786        1766
  2. 2        a_000014        4678
  3. 9        a_000662        2349
  4. 9        a_001160179        2349
  5. 9        a_001160170        2349
  6. 9        a_001160171        2349
  7. 9        a_001160172        2349
  8. 9        a_001160173        2349
  9. 9        a_001160174        2349
  10. 9        a_001160175        2349
  11. 9        a_001160176        2349
  12. 10        a_000015        1317
  13. 12        a_001085        1629
  14. 13        a_001086        1725
  15. 14        a_001087        1859
  16. 15        a_001088        1935
  17. 15        a_001166579        1935
  18. 16        a_001605        3344
  19. 18        a_001127448        5586
  20. 18        a_020686        5586
  21. 18        a_000663        5586
  22. 19        a_005502        10515
  23. 20        a_212533        8171
  24. 20        a_001606        8171
复制代码

作者: personball    时间: 2012-07-12 10:59
回复 1# nb509
  1. personball@vostro:ttt$awk 'NR==FNR&&($3>a[$1]){a[$1]=$3} NR>FNR{$3=a[$1];print $0}'  file   file
  2. 1 a_130786 1766
  3. 2 a_000014 4678
  4. 9 a_000662 2349
  5. 9 a_001160179 2349
  6. 9 a_001160170 2349
  7. 9 a_001160171 2349
  8. 9 a_001160172 2349
  9. 9 a_001160173 2349
  10. 9 a_001160174 2349
  11. 9 a_001160175 2349
  12. 9 a_001160176 2349
  13. 10 a_000015 1317
  14. 12 a_001085 1629
  15. 13 a_001086 1725
  16. 14 a_001087 1859
  17. 15 a_001088 1935
  18. 15 a_001166579 1935
  19. 16 a_001605 3344
  20. 18 a_001127448 5586
  21. 18 a_020686 5586
  22. 18 a_000663 5586
  23. 19 a_005502 10515
  24. 20 a_212533 8171
  25. 20 a_001606 8171
  26. 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
  1. 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