sort命令去重无效的分析

有如下一个文件

1 北京 aa dd
2 南京 bb ad
3 东京 cc as
4 巴黎 aa asd

现在想根据第三列进行去重,命令是

sort -t " " -k 3 -u 文件名

却发现无效,原因是第三列相同,sort会根据第一个域重新排,如果相同,继续后推

所以需要改为:sort -t  " " -k 3,3 -u 文件名 

上面的命令代表只针对第三列排序去重

 

拓展内容:

sort -t  "分隔符" -k n1,n2 -u 文件名   按照分隔符分割,然后按照n1排序去重,n1相同,后移,直到n2列去重完

另外还有小数点的用法

假如想根据第二列的第二个字母和排序,怎么办,(s使用小数点就ok)

sort -t  " " -k 2.2  facebook.txt

如果从第二列的第二个字母到第三列的第三个字母排序怎么办

sort -t  " " -k 2.2,3.3 facebook.txt

今天遇到这个问题了,记录一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值