Linux統(tǒng)計(jì)一個(gè)文件中特定字符個(gè)數(shù)的方法
統(tǒng)計(jì)一個(gè)文件中某個(gè)字符串的個(gè)數(shù),其實(shí)就是在在一塊沙地里面找石頭,有的人看到石頭以后,在上面做個(gè)標(biāo)記(grep),然后記住自己做了多少個(gè)標(biāo)記;有的人看到石頭以后,把它挖了(tr),最后統(tǒng)計(jì)自己挖了多少石頭;有的人看到石頭以后,把它跳過去(awk),然后統(tǒng)計(jì)自己跳了多少次。
這是我用的的文件
[root@bzhou test]# cat file hafsdha hahafsdfsdhaha haha
我想匹配的是‘haha'這個(gè)字符串
1.grep的-o選項(xiàng)
[root@bzhou test]# grep -c 'haha' file 2
最開始的時(shí)候是用-c這個(gè)選項(xiàng),不過-c只能統(tǒng)計(jì)一行的,如果一行里面有多個(gè)匹配的字符串,那-c就無能為力了。
這個(gè)是正確的
[root@bzhou test]# grep -o 'haha' file | wc -l 3
2. awk
這個(gè)東西要感謝CU上的blackold。
[root@bzhou test]# awk -v RS='haha' 'END {print --NR}' file
-v 去設(shè)定一個(gè)變量的值,RS是記錄的分隔符,默認(rèn)的是新行(\n),就是說awk按照一行一行讀數(shù)據(jù),但是現(xiàn)在RS為'haha'后,就按'haha'讀數(shù)據(jù)了,NR為已讀的記錄數(shù),n個(gè)記錄是被n-1個(gè)分隔符分開的,所以就是--NR了。
3.tr
嚴(yán)格意義上說,tr匹配不了字符串,只能去匹配單個(gè)字符。這里就匹配這個(gè)文件中‘h'的個(gè)數(shù)。
[root@bzhou test]# tr -cd 'h' <file | wc -c 8 [root@bzhou test]# grep -o 'h' file | wc -l 8
-d可以刪除某個(gè)字符,如果只有-d就會輸出刪除特定字符后的字符串,但是-c可以反顯,這就是顯示了被刪除的字符。然后可以用wc -c去統(tǒng)計(jì)下字符的個(gè)數(shù)。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
ubuntu開啟SSH服務(wù)遠(yuǎn)程登錄操作的實(shí)現(xiàn)
這篇文章主要介紹了ubuntu開啟SSH服務(wù)遠(yuǎn)程登錄操作的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08centOS7 橋接模式設(shè)置靜態(tài)Ip的方法步驟
這篇文章主要給大家介紹了關(guān)于centOS7 橋接模式設(shè)置靜態(tài)Ip的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用centOS7具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Linux centos如何讓普通用戶獲取root權(quán)限
這篇文章主要介紹了Linux centos如何讓普通用戶獲取root權(quán)限問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05