awk做wordcount

使用awk进行wordcount

被处理数据在文件access_2024-1-21.log(一个单词一行)中,内容如下:

复制代码
word
coutn
wm
sapce
US
china
WORD
WORD
wode
wode
1
2
3333
zzzz
space
spaceX
china
word

执行如下命令可以统计出每个单词出现次数:

复制代码
```bash
 awk '{S[$1]++}END{for(k in S) print S[k],k}' access_2024-1-21.log

结果如下:

root@Oler wm\]# awk '{S\[$1\]++}END{for(k in S) print S\[k\],k}' access_2024-1-21.log 1 spaceX 1 3333 1 zzzz 1 sapce 1 coutn 1 wm 1 space 1 1 1 2 2 china 2 wode 2 WORD 1 US 2 word 命令解释: 此处的S变量表示一个数组,该数组的索引为每个不重复的单词,值就是S\[$1\],$1代表单词那一列。awk是每都一行执行一次动作。 此处就是每读一行,同一个key对应的值就增加一。从0开始计算。当统计完,最后,也就是END对应的内容,就是循环打印出存储了统计结果的数组的key和值。

相关推荐
cui__OaO2 分钟前
Linux内核--基于正点原子IMX6ULL开发板的内核移植
linux·嵌入式
我想发发发3 分钟前
Linux实现虚拟串口通信-socat
linux·运维·服务器
济61712 分钟前
linux 系统移植(第五期)--Uboot移植(4)--在U-Boot 中添加自己的开发板(4) -其他需要修改的地方-- Ubuntu20.04
linux·运维·服务器
老顾聊技术30 分钟前
“Anthropic 最新发布的 AI Skills:赋能任务自动化与跨领域应用“
运维·人工智能·自动化
令狐少侠201137 分钟前
Linux 系统部署夜莺 nightingale 监控公司的watchdog
linux·运维·服务器
信工 18021 小时前
RK3588系统烧录后扩容
linux·rk3588
Jay Chou why did1 小时前
程序启动地址0x80000000
linux
kkce1 小时前
域名CDN检测意义
服务器·前端·网络
百度Geek说1 小时前
百度流式计算开发平台的降本增效之路
运维·云原生
e***98572 小时前
MobaXterm全能运维实战指南
运维