Chinaunix首页 | 论坛 | 博客
  • 博客访问: 274592
  • 博文数量: 64
  • 博客积分: 1758
  • 博客等级: 上尉
  • 技术积分: 543
  • 用 户 组: 普通用户
  • 注册时间: 2010-11-25 11:13
文章分类
文章存档

2011年(54)

2010年(10)

我的朋友

分类: Python/Ruby

2011-05-03 17:06:20

有一个文本,存在以下内容:
 
A 10 20 30
B 20 40 10
C 3 6 9
 
现在通过awk实现以下几种结果:
 
1. 打印每行第一列各列数字之和:
 
awk '{Total=0;for(i=2;i<=NF;i++) Total+=$i}{printf("%s %d\n", $1,Total)}' file.txt
 
2. 打印每行第一列后各数字中最大的值:
 
awk '{for(i=2;i<=NF;i++) max=$i?$i:max;printf("%s %d\n", $1,max)}' test.txt
 
3. 打印第二列值之和;
 
awk '{total+=$2} END {print total;}' test.txt
 
 
 
阅读(947) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~