Chinaunix首页 | 论坛 | 博客
  • 博客访问: 124231
  • 博文数量: 22
  • 博客积分: 948
  • 博客等级: 准尉
  • 技术积分: 225
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-08 15:50
文章分类

全部博文(22)

文章存档

2015年(1)

2013年(1)

2010年(1)

2009年(19)

我的朋友

分类: LINUX

2009-07-11 08:44:29

如下题:
文本:test.log
X001        100
X002        121
X003        12
X004        13
X005        14
X006        23
X007        344
X008        1234
X009        1
X010        10
X011        123

其中第二列为数值,以第二列数值之和为200分段,如下:
X001        X002        221                    ---------前两行之和大于200,打印第一列开始结束值
X003        X007        406                    ---------第3,4,5,6,7行的第二列值和大于200,打印第一列开始结束值
X008        X008        1234                  ---------第8行的第二列值本身已大于200,打印第一列开始结束值
X009        X011        134                  ---------文本结束,虽不足200值,仍打印第一列开始结束值。

各位高手,有没有更优更简单的实现方法?

引用   帅哥 (黑哥) 的解决方案:
awk 'f{t+=$2}!f{printf $1;f=!f;t=$2}t>200{printf "\t%s\t%s\n", $1,t;f=!f}END{if(f)printf "\t%s\t%s\n",$1,t}' urfile

原帖网址:


阅读(1466) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~