[英]Count value in shell script
我需要幫助,我有一個文件output.txt
ttl 128
ttl 128
ttl 128
ttl 128
ttl 1
ttl 128
ttl 255
ttl 1
ttl 64
ttl 128
ttl 128
ttl 1
我需要計算在文件行中出現相同值的次數。 最終結果必須是這樣的:
ttl 128 - 7 times
ttl 64 - 1 time
ttl 255 - 1 time
ttl 1 - 3 times
我希望你能幫助我。 我正在嘗試使用grep命令。
非常感謝
您可以使用uniq
和sort
做到這一點:
<output.txt sort -V | uniq -c
輸出:
3 ttl 1
1 ttl 64
7 ttl 128
1 ttl 255
排序,uniq足以勝任這項工作。 但是,要獲得與上述問題相同的輸出格式,請嘗試以下awk行
awk '{a[$0]++}END{for(x in a){t=a[x]>1?"times":"time";print x " - "a[x],t}} file
例如
times
,否則time
不帶s。 輸出為:
ttl 1 - 3 times
ttl 64 - 1 time
ttl 128 - 7 times
ttl 255 - 1 time
:)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.