加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 如何基于列排序,但基于另一列的uniq?

发布时间:2020-05-23 15:31:35 所属栏目:Linux 来源:互联网
导读:他全部, 我有一个包含一些列的文件.我想对第2列进行排序然后将uniq应用于第1列.我发现这个 post在同一列中讨论了sort和uniq,但我的问题有点不同.我正在考虑使用sort和uniq但不知道如何使用.谢谢. 您可以使用管道,但它不到位. 示例: $cat initial.txt1,3,42,3

他全部,
我有一个包含一些列的文件.我想对第2列进行排序然后将uniq应用于第1列.我发现这个 post在同一列中讨论了sort和uniq,但我的问题有点不同.我正在考虑使用sort和uniq但不知道如何使用.谢谢.

解决方法

您可以使用管道,但它不到位.

示例:

$cat initial.txt
1,3,4
2,1
1,2,3
2,4
1,4,1
3,1,3
4,4

$cat initial.txt | sort -u -t,-k1,1 | sort -t,-k2,2
3,1

结果按键2排序,按键1唯一.注意结果显示在控制台上,如果你想在文件中,只需使用重定向(> newFiletxt)

这种更复杂操作的其他解决方案是依赖于另一种工具(取决于您的偏好(和年龄),awk,perl或python)

编辑:
如果我理解正确的新要求,它按字母2排序,第1列对于给定的列2是唯一的:

$cat initial.txt | sort -u -t,2 | sort -t,3
1,1

这是你期望的吗?否则,我不明白:-)

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读