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,请注明来意。
标签: