shell脚本去重的几种方法
测试文件如下:
jason jason jason fffff jason
第一种去重方法:sort -u 文件名 或者 cat 文件名 | sort -u
[root@bogon ~]# sort -u test fffff jason
但这样只是将去重后的结果打印在屏幕上,如果想将去重后的内容保存下来,语句为:
sort -u 文件名 > 新文件名
或者
cat 文件名 | sort -u > 新文件名
即可将去重后的内容保存在新文件名中
第二种方法:uniq 文件名 或者 cat 文件名 | uniq
[root@bogon ~]# uniq test jason fffff jason
由此可见,uniq需要先排序后才能去重,同时将去重后的结果保存在新文件中:cat 文件名 | sort | uniq > 新文件名
第三种去重方法: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 ~]# sort -k 1,1 -u test fffff jason
查看sort的用法,-k参数是这么描述的:
-k, --key=POS1[,POS2]
start a key at POS1 (origin 1), end it at POS2 (default end of line)
也就是说-k哪几个列进行排序,pos1是开始列,pos2是结束列
————————————————---------------------------
原文链接:https://blog.csdn.net/laobai1015/article/details/91455406
posted on 2022-11-26 23:52 RICH-ATONE 阅读(3146) 评论(0) 编辑 收藏 举报