LINUX統計一個文件中特定字符串出現的次數

 
[root@bzhou test]# cat file
hafsdha
hahafsdfsdhaha
haha
 
我想匹配的是‘haha’這個字符串
1.grep的-o選項
[root@bzhou test]# grep -c 'haha' file
2
 
最開始的時候是用-c這個選項,不過-c只能統計一行的,若是一行裏面有多個匹配的字符串,那-c就無能爲力了。
這個是正確的
[root@bzhou test]# grep -o 'haha' file | wc -l
3
 
2. awk
這個東西要感謝CU上的blackold。
[root@bzhou test]# awk -v RS='haha' 'END {print --NR}' file
 
-v 去設定一個變量的值,RS是記錄的分隔符,默認的是新行(\n),就是說awk按照一行一行讀數據,可是如今RS爲'haha'後,就按'haha'讀數據了,NR爲已讀的記錄數,n個記錄是被n-1個分隔符分開的,因此就是--NR了。
3.tr
嚴格意義上說,tr匹配不了字符串,只能去匹配單個字符。這裏就匹配這個文件中‘h’的個數。
[root@bzhou test]# tr -cd 'h'
8
[root@bzhou test]# grep -o 'h' file | wc -l
8
 
-d能夠刪除某個字符,若是隻有-d就會輸出刪除特定字符後的字符串,可是-c能夠反顯,這就是顯示了被刪除的字符。而後能夠用wc -c去統計下字符的個數。
相關文章
相關標籤/搜索