Chinaunix首页 | 论坛 | 博客
  • 博客访问: 134004
  • 博文数量: 37
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 0
  • 用 户 组: 普通用户
  • 注册时间: 2016-07-02 01:04
个人简介

CU

文章分类

全部博文(37)

文章存档

2016年(33)

2015年(4)

我的朋友

分类: LINUX

2016-01-21 18:06:47

把第一列相同的名称的第二列加起来:
cat add
111 1
222 3
111 4
111 5
222 2
333 3
444 4
333 3

cat add   | awk '{a[$1]+=$2}END{for(i in a) printf
"%s %d\n",i,a[i]}'
444 4
111 10
333 6
222 5
(把含有111的行的第二列加起来等于10)
cat add   | awk '{a[$1]+=$2}END{for(i in a) printf
"%s %d\n",i,a[i]}' | sort -n -r -k2
111 10
333 6
222 5
444 4
cat add   | awk
'{a[$1]+=$2}END{for(i in a) printf "%s %d\n",i,a[i]}' | sort -n -r -k1
444 4
333 6
222 5
111 10

简单的把第二列加起来:
cat
add | awk '{a=a+$2}END{print a}'
阅读(1663) | 评论(0) | 转发(0) |
0

上一篇:查询最高分数

下一篇:NR和FNR的典型应用

给主人留下些什么吧!~~