uniq [OPTION]… [INPUT [OUTPUT]]
| -c | --count | Prefix lines by the number of occurrences | |
| -d | --repeated | Only print duplicate lines, one for each group. This option is very useful to determine if a text contains duplicated lines. | |
| -D | Print all duplicate lines | ||
| --all-repeated | [=METHOD] | Like -D, but allow separating groups with an empty line.METHODis one ofnone(the default),prependorseparate | |
| -f | --skip-fields= | N | Avoid comparing the first Nfields | 
| --group | [=METHOD] | Show all items, separating groups with an empty line. METHODis one ofseparate(the default),prepend,appendorboth | |
| -i | --ignore-case | Ignore differences in case when comparing | |
| -s | --skip-chars= | N | Avoid comparing the first Ncharacters | 
| -u | --unique | Only print unique lines | |
| -z | --zero-terminated | Line delimiter is NUL, not line break | |
| -w | --check-chars= | N | Compare no more than Ncharacters in lines | 
| --help | |||
| --version | 
-d options allows to quickly determine if a file contains duplicated lines. echo 'This text does not have duplicates' | sort | uniq -d
echo 'in this text, the word this occurs twice' | sort | uniq -d
$ git log --format='%aN' | sort | uniq -c | sort -nr
uniq does not detect repeated lines unless they are adjacent. sort -u (without uniq).