首頁 > 軟體

Linux uniq命令

2020-06-16 17:08:48

uniq是去重,不相鄰的行不算重複值。

uniq [OPTION]... [INPUT [OUTPUT]]

選項說明:

-c:統計出現的次數(count)。

-d:只顯示被計算為重複的

-D:顯示所有被計算為重複的

-u:顯示唯一值,即沒有重複值的

-i:忽略大小寫。

-z:在末尾使用,而不是換行符。

-f:跳過多少個欄位(field)開始比較重複值。

-s:跳過多少個字元開始比較重複值。

-w:比較重複值時每行比較的最大長度。即對每行多長的字元進行比較。

範例:

[root@linuxidc tmp]# cat uniq.txt
111
223
56
111
111
567
223

下面的命令刪除了相鄰的重複行,但是第一行111沒有刪除。

[root@linuxidc tmp]# uniq uniq.txt
111
223
56
111   # 刪除了重複的111
567
223

排序後去重。

[root@linuxidc tmp]# sort uniq.txt | uniq
111
223
56
567

使用-d顯示重複的行。

[root@linuxidc tmp]# sort uniq.txt | uniq  -d
111
223

使用-D顯示所有重複過的行。

[root@linuxidc tmp]# sort uniq.txt | uniq  -D
111
111
111
223
223

使用-u顯示唯一行。

[root@linuxidc tmp]# sort uniq.txt | uniq  -u
56
567

使用-c統計哪些記錄出現的次數。

[root@linuxidc tmp]# sort uniq.txt | uniq  -c  
      3 111
      2 223
      1 56
      1 567

使用-d -c統計重複行出現的次數。

[root@linuxidc tmp]# sort uniq.txt | uniq  -d -c
      3 111
      2 223

-c不能和-D一起使用。結果說顯示所有重複行再統計重複次數是毫無意義的行為。

[root@linuxidc tmp]# sort uniq.txt | uniq  -D -c
uniq: printing all duplicated lines and repeat counts is meaningless
Try `uniq --help' for more information.

本文永久更新連結地址http://www.linuxidc.com/Linux/2017-08/146608.htm


IT145.com E-mail:sddin#qq.com