通过awk 命令, 进行awk的计算统计
首先创建一个文件test.txt。 内容如下:
cat test.txt
123 2 1
321 2 1
123 2 1
321 2 1
10 1 1
第一个:以第一列为分组,进行第二列求和
awk '{ s[$1] += $2 } END { for ( i in s ) { print i , s[i]}}' test.txt
10 1
321 4
123 4
第二个:求取第一列的总和
awk 'BEGIN{ sum =0 }{ sum += $1 }END{ print sum}' test.txt
898
上面对比缺少负值,我们来添加负值再进行最大值,最小值,求和运算
[xxxxxx ~]$ cat test.txt
123 2 1
321 2 1
123 2 1
321 2 1
10 1 1
-10 1 1
-3 1 1
最大值: 截取第一列的最大值
awk 'BEGIN{MAX=0}{if( $1 > MAX) MAX=$1}END{print MAX}' test.txt
321
最小值:截取第一列中的最小值
awk 'BEGIN{MIN=0}{if( $1 < MIN) MIN=$1}END{print MIN}' test.txt
-10
求和:获取第一列数据的求和
awk 'BEGIN{SUM=0}{ SUM += $1}END{print SUM}' test.txt885
只是针对数值的计算获取,没有进行针对存在字符串的尝试测试。