sort命令去重无效的分析

版权声明:转载请注明出处 https://blog.csdn.net/qq_27563511/article/details/83444481

有如下一个文件

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

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

猜你喜欢

转载自blog.csdn.net/qq_27563511/article/details/83444481