Linux
发布时间:2022-03-31 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了linux – 如何使用以下要求对列进行排序,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
概述
我有3列 a 03 w
a 10 x
a 01 y
b 20 w
b 01 x
c 02 w
c 10 y
c 12 z 预期的产出是 a 10 x
b 20 w
c 12 z 即我需要对第2列进行排序,但不改变第1列的顺序 然后基于第二列grep列表中最大值的行 两种方法(选择一种你喜欢的方式): 1)排序uniq“技巧”: sort -k1,1 -k2,2rn file | uniq -w1
我有3列
a 03 w
a 10 x
a 01 y
b 20 w
b 01 x
c 02 w
c 10 y
c 12 z
预期的产出是
a 10 x
b 20 w
c 12 z
即我需要对第2列进行排序,但不改变第1列的顺序
然后基于第二列grep列表中最大值的行
两种
方法(选择一种你喜欢的方式):
1)排序uniq“技巧”:
sort -k1,1 -k2,2rn file | uniq -w1
> -k1,1 – 按第1阶段的第1个字段排序
> -k2,2rn – 按相反顺序对第2个字段的数字排序
> uniq -w1 – 输出行中不超过1个字符的唯一行(可以调整-w< number>)
输出:
a 10 x
b 20 w
c 12 z
2)只需使用GNU datamash工具:
datamash -Wsf -g1 max 2 <file | cut -f1-3
输出:
a 10 x
b 20 w
c 12 z
大佬总结
以上是大佬教程为你收集整理的linux – 如何使用以下要求对列进行排序全部内容,希望文章能够帮你解决linux – 如何使用以下要求对列进行排序所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。