awk查找数组的最小值和最大值

时间:2016-02-24 09:26:35

标签: arrays for-loop awk

我的文件生成不同的ID并计数如下所示

prod1 13
prod4 14
prod5 14
prod3 11
prod2 8
prod1 9
prod3 16
prod5 11
prod2 9
prod4 11
prod1 16
prod5 8
prod3 16
prod2 3
prod4 1
prod3 3
prod2 1
prod1 1
prod5 3
prod1 2
prod4 78

我正在尝试找到获得每种产品的最大值和最小值的选项。

运行以下awk脚本可以获得计数和总和,但我还需要跟踪每个产品的最小值和最大值。

awk '{ Prod[$1]++; sum[$1]+=$2 } END{ for (var in Prod) print var, "count", Prod[var], "and sum", sum[var]}'

prod1 count 5 and sum 41
prod2 count 4 and sum 21
prod3 count 4 and sum 46
prod4 count 4 and sum 104
prod5 count 4 and sum 36

有没有办法修改awk数组脚本以获取最大值和最小值?

谢谢!

1 个答案:

答案 0 :(得分:2)

  awk '{Prod[$1]++
    sum[$1]+=$2
    min[$1]=Prod[$1]==1||min[$1]>$2?$2:min[$1]
    max[$1]=max[$1]<$2?$2:max[$1]} 
    END{ for (var in Prod) printf "%s count %d and sum %d max %d min %d\n", var,Prod[var],sum[var],max[var],min[var]}' file

给出

prod4 count 4 and sum 104 max 78 min 1
prod5 count 4 and sum 36 max 14 min 3
prod1 count 5 and sum 41 max 16 min 1
prod2 count 4 and sum 21 max 9 min 1
prod3 count 4 and sum 46 max 16 min 3