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

相关推荐
Yiyaoshujuku15 小时前
化学谱图数据API接口,数据字段一览!
linux·服务器·前端
__Witheart__15 小时前
make menuconfig 使用全流程
linux·ubuntu·rockchip
2601_9516457815 小时前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
阿坤带你走近大数据15 小时前
Linux中管道符的作用
java·linux·服务器
Fcy64815 小时前
Linux下 进程信号初识和信号的产生
linux·运维·信号的产生
爱装代码的小瓶子15 小时前
安工大Linux考点分类真题解析(含知识点是试卷原题了)
linux·服务器·网络·c
hweiyu0015 小时前
Linux命令:sudoedit
linux·运维·服务器
qq_1631357515 小时前
Linux 【03-nl命令超详细教程】
linux
lpl31290550915 小时前
skynet 共享数据原理
服务器·c语言·lua
ShGamu15 小时前
自动化输送设备公司选型参考与核心维度梳理
运维·自动化·自动化输送设备