有如下一个文件
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
今天遇到这个问题了,记录一下