Linux之uniq命令

举报
入门小站 发表于 2021/08/21 22:46:55 2021/08/21
【摘要】 显示或忽略重复的行。 命令格式uniq [选项]... [文件] 命令选型-c, --count 在每行开头增加重复次数。-d, --repeated 所有邻近的重复行只被打印一次。-D 所有邻近的重复行将全部打印。–all-repeated[=METHOD] 类似于 -D,但允许每组...

显示或忽略重复的行。

命令格式

uniq [选项]... [文件]

命令选型

  • -c, --count 在每行开头增加重复次数。
  • -d, --repeated 所有邻近的重复行只被打印一次。
  • -D 所有邻近的重复行将全部打印。
  • –all-repeated[=METHOD] 类似于 -D,但允许每组之间以空行分割。METHOD取值范围{none(默认),prepend,separate}。
  • -f, --skip-fields=N 跳过对前N个列的比较。
  • –group[=METHOD] 显示所有行,允许每组之间以空行分割。METHOD取值范围:{separate(默认),prepend,append,both}。
  • -i, --ignore-case 忽略大小写的差异。
  • -s, --skip-chars=N 跳过对前N个字符的比较。
  • -u, --unique 只打印非邻近的重复行。
  • -z, --zero-terminated 设置行终止符为NUL(空),而不是换行符。
  • -w, --check-chars=N 只对每行前N个字符进行比较。
  • –help 显示帮助信息并退出。
  • –version 显示版本信息并退出。

命令参数

  • INPUT(可选):输入文件,不提供时为标准输入。
  • OUTPUT(可选):输出文件,不提供时为标准输出。

命令返回值

返回0表示成功,返回非0值表示失败。

实验文本

> cat 1.txt
123
456
789
123
123
333
123
eee
rrr

相邻行去重

> uniq 1.txt
123
456
789
123
333
123
eee
rrr

文件每行排序后,相邻行去重

> sort 1.txt | uniq
123
333
456
789
eee
rrr

//或者
> sort -u 1.txt 
123
333
456
789
eee
rrr

统计各行在文件中出现的次数

> sort 1.txt  | uniq -c
      4 123
      1 333
      1 456
      1 789
      1 eee
      1 rrr

先排序后统计重复的次数

查找文件中重复的行

> sort 1.txt | uniq -d
123

uniq只检测邻近的行是否重复,sort -u将输入文件先排序然后再处理重复行

忽略每行的前N个字符

> uniq -s 3 1.txt

忽略每行的前3个字符,比较后面的字符

只对前N个字符进行比较

> uniq -w 3 1.txt

只对每行的前3个字符进行比较

原文链接:https://rumenz.com/rumenbiji/linux-uniq.html
微信公众号:入门小站

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。