linux shell中統計文本中指定單詞出現的次數


linux shell中統計文本中指定單詞出現的次數

1、測試數據, 統計 a.txt中e出現的總次數

root@PC1:/home/test/test# cat a.txt
e r e y e u e
e e g e 3 h r
1 3 e g e y e
e s e e e e e

 

2、awk實現

root@PC1:/home/test/test# cat a.txt
e r e y e u e
e e g e 3 h r
1 3 e g e y e
e s e e e e e
root@PC1:/home/test/test# awk -v RS="@##@#" '{print gsub(/e/, "&")}' a.txt ## RS 指定行分割符,意思是把文本當做一行,然后統計一行中所有e的數目 16

 

3、grep實現

root@PC1:/home/test/test# cat a.txt
e r e y e u e
e e g e 3 h r
1 3 e g e y e
e s e e e e e
root@PC1:/home/test/test# grep -o "e" a.txt
e
e
e
e
e
e
e
e
e
e
e
e
e
e
e
e
root@PC1:/home/test/test# grep -o "e" a.txt | wc -l ## grep -o列出所有匹配的字符,匹配一次占用一行,最后統計行數即可 16

 

4、sed實現

root@PC1:/home/test/test# cat a.txt
e r e y e u e
e e g e 3 h r
1 3 e g e y e
e s e e e e e
root@PC1:/home/test/test# sed 's/ /\n/g' a.txt ## 將所有空格替換為換行符
e
r
e
y
e
u
e
e
e
g
e
3
h
r
1
3
e
g
e
y
e
e
s
e
e
e
e
e
root@PC1:/home/test/test# sed 's/ /\n/g' a.txt | sed -n '/e/p'   ## 利用sed 打印 匹配e的行
e
e
e
e
e
e
e
e
e
e
e
e
e
e
e
e
root@PC1:/home/test/test# sed 's/ /\n/g' a.txt | sed -n '/e/p' | sed -n "$="   ## 最后統計行數即可
16

 

5、vim實現

root@PC1:/home/test/test# vim a.txt

e r e y e u e
e e g e 3 h r
1 3 e g e y e
e s e e e e e
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
~
:%s/e//gn

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM