首页 > 代码库 > awk数组结合+=统计题
awk数组结合+=统计题
文件如下
61.144.83.198 594 61.144.83.198 576 61.144.83.198 573 219.137.178.228 570 219.137.178.228 565 61.144.83.198 553 61.144.83.198 550 61.144.83.198 549
每一行以空格为分隔符,第一列是ip,第二列为不定数值
需求,现在想要将相同ip后的不定数值相加统计出来
awk ‘{a[$1]+=$2}END{for(i in a)print i,a[i]}‘ file
思路:
将ip作为a[]数组的下标,将$2中的内容赋值给a[$1]即a[ip],得到数组a[ip]=value
执行语句a[ip]+=value,这样同样的a[ip]中的值就会与下一行的$2相加,然后得到新的值,继续执行
直到文件末尾执行完毕
END模块
用变量i读取数组的下标,再取出数值a[i]即value值
最终得到结果
awk数组结合+=统计题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。