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 Sk,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和值。

相关推荐
云飞云共享云桌面5 分钟前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
JAVA面经实录9171 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
小刘|2 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
暮云星影3 小时前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
Maynor9963 小时前
我用 Codex 给自己的网站上线了一个智能体客服:从 Dify 到服务器部署,全程实战复盘
运维·服务器
聚名网3 小时前
域名net,com,cn有区别吗?有哪些不同呢?
服务器·开发语言·php
java_cj4 小时前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
小小小花儿4 小时前
SSH密钥配置(免密连接远程服务器)
服务器·ssh
swordbob4 小时前
NIO 的 Channel 里有多个 BIO 吗?
linux·网络·nio
深圳恒讯5 小时前
越南服务器BGP多线和单线有什么区别?
运维·服务器