shell脚本去重的几种方法

  • 测试文件
[root@bogon ~]# cat >test
jason
jason
jason
fffff
jason

按 Ctr + D保存测试

一、sort -uspa

[root@bogon ~]# sort -u test
fffff
jason

二、uniqcode

[root@bogon ~]# uniq test
jason
fffff
jason

因而可知,uniq须要先排序后才能去重blog

三、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
  •   根据某个字段去重

  将原有数据改成it

[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参数是这么描述的:class

    -k, --key=POS1[,POS2]
    start a key at POS1 (origin 1), end it at POS2 (default end of line)test

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

相关文章
相关标签/搜索