gawk '$9=="404" || $9=="403"' log.txt | gawk '{print $7}' | sort -k7 | uniq -c | sort -nr
输出:
28 /example/.comments
9 /example/example.atom.xml
8 /example/When/200x/2003/04/10/-big/Concorde.jpg
7 /example/When/200x/2006/03/30/-big/IMG_4613.jpg
6 /example/When/200x/2003/07/25/-big/guild-2.jpg
5 /example/Patti-Smith.png
如何在名称 url 后打印 uniq 号码?并用数字打印
1. /example/.comments - 28
2. /example/example.atom.xml - 9
3. /example/When/200x/2003/04/10/-big/Concorde.jpg - 8
4. /example/When/200x/2006/03/30/-big/IMG_4613.jpg - 7
5. /example/When/200x/2003/07/25/-big/guild-2.jpg - 6
6. /example/Patti-Smith.png - 5
7. /example/IMGP4289-2.png - 5
8. /example/IMGP4287.png - 5
9. /example/Image-Search-Mystery.png - 5
10. /example/Horses.png - 5
11. /example/When/200x/2004/02/27/-big/Unreal.png - 4
答案1
以下awk
命令将修改每个输入行,以便将第一个字段复制到新的最后一个字段并以破折号作为前缀。然后,第一个字段将替换为行号,后跟一个点。
awk '{ $(NF+1) = "-"; $(NF+1) = $1; $1 = NR "."; print }'
因此,将两个awk
调用组合sort | uniq -c
在初始管道中并将其标记到末尾:
awk '
$9 ~ /^40[34]$/ { count[$7]++ }
END { for (a in count) print count[a], a }' log.txt |
sort -nr |
awk '{ $(NF+1) = "-"; $(NF+1) = $1; $1 = NR "."; print }'
如果您碰巧拥有 GNU awk
(常见于 Linux 系统等)4.0 或更高版本,那么您也可以执行以下sort -nr
操作awk
:
awk '
$9 ~ /^40[34]$/ { count[$7]++ }
END {
PROCINFO["sorted_in"] = "@val_num_desc"
for (a in count)
print ++i ".", a, "-", count[a]
}' log.txt