linux shell中統計文字中指定單詞出現的次數
阿新 • • 發佈:2021-12-14
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