您的位置:首页 > 运维架构 > Linux

使用Linux命令统计文件指定列中字符串出现次数

2017-09-07 14:40 471 查看

使用脚本生成测试文件,内容为几种编程语言的随机列表

此处使用了$RANDOM来生成随机数

生成一个样例文件,如test_201709,文件内容只有一列

#!/bin/bash

generate_file="test_$(date +%Y%m)"
names=(Java Shell C C++ Python Php Go)
names_length=${#names[@]}
rm -f ${generate_file}
for i in {1..200}
do
random_num=$RANDOM
index=$((random_num%names_length))
echo "${names[${index}]}" >> ${generate_file}
done


统计各个语言出现的次数(以下测试中的次数重新生成文件后会不一样)

此处文件名可直接使用上述文件名规则test_$(date +%Y%m)

sort test_$(date +%Y%m) | uniq -c


执行结果如下,第一列为次数:

26 C
27 C++
32 Go
27 Java
33 Php
29 Python
26 Shell


按出现次数由高到底排序

sort test_$(date +%Y%m) | uniq -c | sort -k1,1nr


执行结果如下:

33 Php
32 Go
29 Python
27 C++
27 Java
26 C
26 Shell


找出出现次数最高或者最低的三种语言

1.次数最高三种语言

sort test_$(date +%Y%m) | uniq -c | sort -k1,1nr | head -3


执行结果如下:

33 Php
32 Go
29 Python


2.次数最低三种语言

1)次数最低语言由高到低排序展示

sort test_$(date +%Y%m) | uniq -c | sort -k1,1nr | tail -3


执行结果如下:

27 Java
26 C
26 Shel


2)次数最低语言由低到高排序展示

sort test_$(date +%Y%m) | uniq -c | sort -k1,1n | head -3


执行结果如下:

26 C
26 Shel
27 Java


以上操作针对是单列的文件,若对多列文件可用awk命令拆分出列,再进行以上操作即可

awk的-F选项可以指定分割符,默认分割符为空字符,获取某一列命令如下

n需要替换为具体列数

awk '{print $n}' file_name
awk -F ',' '{print $n}' file_name


若需要查找第二列出现次数前三且列分割符为’,’,命令如下:

awk -F ',' '{print $2}' file_name | sort | uniq -c | sort -k1,1nr | head -3


查看文件行数

file_name 可为多个文件,为多个时会把总行数显示,并且此时
4000
可按照行数排序来查找文件

wc -l file_name


例如在我当前测试目录下执行wl -l ./* 显示如下:

12 ./generate.sh
200 ./test_201709
212 total
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  shell sort uniq awk linux