我的文件生成不同的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数组脚本以获取最大值和最小值?
谢谢!
答案 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