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

复制代码

 

 

posted @   小鲨鱼2018  阅读(1312)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
历史上的今天:
2020-12-14 linux系统中部署vsftpd服务(虚拟用户模式)
2020-12-14 linux系统中部署vsftpd服务(本地用户模式)
2020-12-14 linux系统中安装ifconfig命令
点击右上角即可分享
微信分享提示