免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1955 | 回复: 5
打印 上一主题 下一主题

取最大值。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 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
复制代码

论坛徽章:
0
2 [报告]
发表于 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$
复制代码

论坛徽章:
0
3 [报告]
发表于 2012-07-12 11:00 |只看该作者
先排序一下,应该好处理一点。
sort -k 1,1n -k 3,3nr

论坛徽章:
0
4 [报告]
发表于 2012-07-12 11:06 |只看该作者
回复 2# personball

为什么我跑出来的结果文件是空的???


   

论坛徽章:
0
5 [报告]
发表于 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
复制代码

论坛徽章:
0
6 [报告]
发表于 2012-07-12 11:34 |只看该作者
多谢两位。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP