linux ---awk的计算统计

通过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.txt 
885

只是针对数值的计算获取,没有进行针对存在字符串的尝试测试。 




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值