Shell脚本去重的几种方法实例

测试文件

代码如下:

[root@bogon ~]# cat >test

jason

jason

jason

fffff

jason

按 Ctr + D保存

1、sort -u

代码如下:

[root@bogon ~]# sort -u test

fffff

jason

2、uniq

代码如下:

[root@bogon ~]# uniq test

jason

fffff

jason

由此可见,uniq需要先排序后才能去重

3、sort、管道和uniq结合运用
去除重复并保留一份重复的数据

代码如下:

[root@bogon ~]# sort test|uniq

fffff

jason

  去除所有重复的行(不保留重复的行),并计算行数

代码如下:

[root@bogon ~]# sort test|uniq -uc

      1 fffff

  找出所有重复的行,并计算行数

代码如下:

[root@bogon ~]# sort test|uniq -dc

      4 jason

根据某个字段去重

将原有数据改为

代码如下:

[root@bogon ~]# more test

jason 1

jason 2

jason 1

fffff 2

jason 3

[root@bogon ~]# sort -k 1,1 -u test

fffff 2

jason 1

  man sort查看sort的用法,-k参数是这么描述的:

代码如下:

    -k, --key=POS1[,POS2]

    start a key at POS1 (origin 1), end it at POS2 (default end of line)

  也就是说-k哪几个列进行排序,pos1是开始列,pos2是结束列

相关推荐