gpt4 book ai didi

linux - awk 第一列日期的第二列最大值

转载 作者:太空宇宙 更新时间:2023-11-04 11:06:14 25 4
gpt4 key购买 nike

我正在尝试为第一列中的日期仅打印第二列的最大值。

我的文件是:

2014-04-09,135303
2014-04-09,416400
2014-04-15,143684
2014-04-15,156011
2014-04-15,184406
2014-04-16,1123083
2014-04-16,167486
2014-04-16,862196
2014-04-17,963023
2014-04-19,583844

要求的输出:

2014-04-09,416400
2014-04-15,184406
2014-04-16,1123083
2014-04-17,963023
2014-04-19,583844

我试过排序但没有工作:

cat file|sort -k2 -r | sort --unique --stable -k1

请建议如何使用 awk 或 sort 完成

最佳答案

kent$  awk -F, '{a[$1]=$2>a[$1]?$2:a[$1]}END{for(x in a)print x "," a[x]}' file
2014-04-15,184406
2014-04-16,1123083
2014-04-17,963023
2014-04-09,416400
2014-04-19,583844

如果您希望结果按日期排序,将上面的行通过管道传递给 sort:

awk -F, '{a[$1]=$2>a[$1]?$2:a[$1]}END{for(x in a)print x "," a[x]}' f|sort 
2014-04-09,416400
2014-04-15,184406
2014-04-16,1123083
2014-04-17,963023
2014-04-19,583844

关于linux - awk 第一列日期的第二列最大值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25165684/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com