免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5998 | 回复: 7
打印 上一主题 下一主题

多判断条件awk编写请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-15 12:12 |只看该作者 |倒序浏览
白硎 2004  801  2000           2100          1.1
白硎 2004  802  1700           1800          .9
我需要把以上数据做筛选,请教一下怎么写好:
1、判断第二栏位是否大于1980,如果小于退出,大于继续。
2、如果大于1980,那么对第三栏位进行判断,如果大于三个字符,那么把前两个字符和后两个字符分别提出,如果是三个字符把第一个字符和后两个字符分别提出,比如,801运行完之后输出两列:8和01,如果是1814,输出结果是18和14。
3、同第三栏位相同,第四和第五也需要判断是三个字符还是四个字符,如果是三个,如果是三个字符把第一个字符和后两个字符分别提出,如果是四个,那么把前两个字符和后两个字符分别提出。
新手,希望大侠指教

[ 本帖最后由 kevinwell 于 2009-3-15 12:20 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-03-15 13:06 |只看该作者
判断 if
退出 next;
长度 length
截取 substr

论坛徽章:
0
3 [报告]
发表于 2009-03-15 13:43 |只看该作者
awk -F"[ \t]+" '{if(length($2)==3){exit};if(length($2)>3){if(length($3)==3){$3=substr($3,1,1)" "substr($3,2)}else{$3=substr($3,1,2)" "substr($3,3)};if(length($4)==3){$4=substr($4,1,1)" "substr($4,2)}else{$4=substr($4,1,2)" "substr($4,3)}};print $0}' data

这样吗?

[ 本帖最后由 sunbw001 于 2009-3-15 13:45 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2009-03-15 13:56 |只看该作者
awk -F"[ \t]+" '{if(length($2)==3){exit};if(length($2)>3){for(it=3;it<=5;it++){if(length($it)==3){$it=substr($it,1,1)" "substr($it,2)}else{$it=substr($it,1,2)" "substr($it,3)}}};print $0}' data

简单点

论坛徽章:
0
5 [报告]
发表于 2009-03-15 23:48 |只看该作者
if(...)
statements
elseif(...)
statements
elseif()
...
else



C里咋用,这里就咋用吧

论坛徽章:
0
6 [报告]
发表于 2009-03-16 08:46 |只看该作者
楼上说得对!!

论坛徽章:
28
2015年迎新春徽章
日期:2015-03-04 10:16:53午马
日期:2015-03-20 17:11:07亥猪
日期:2015-03-20 17:11:23戌狗
日期:2015-03-20 17:11:33酉鸡
日期:2015-03-20 17:11:47申猴
日期:2015-03-20 17:11:58未羊
日期:2015-03-20 17:12:10子鼠
日期:2015-03-20 17:12:23丑牛
日期:2015-03-20 17:12:40卯兔
日期:2015-03-20 17:12:51辰龙
日期:2015-03-20 17:13:00巳蛇
日期:2015-03-20 17:13:12
7 [报告]
发表于 2015-03-12 23:39 |只看该作者
本帖最后由 我是一隻羊 于 2015-03-12 23:39 编辑

回错地方了,抱歉.

求职 : 机器学习
论坛徽章:
79
2015年亚洲杯纪念徽章
日期:2015-05-06 19:18:572015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之阿尔纳斯尔
日期:2015-09-07 09:30:232015亚冠之萨济拖拉机
日期:2015-10-21 08:26:3915-16赛季CBA联赛之浙江
日期:2015-12-30 09:59:1815-16赛季CBA联赛之浙江
日期:2016-01-10 12:35:21技术图书徽章
日期:2016-01-15 11:07:2015-16赛季CBA联赛之新疆
日期:2016-02-24 13:46:0215-16赛季CBA联赛之吉林
日期:2016-06-26 01:07:172015-2016NBA季后赛纪念章
日期:2016-06-28 17:44:45黑曼巴
日期:2016-06-28 17:44:4515-16赛季CBA联赛之浙江
日期:2017-07-18 13:41:54
8 [报告]
发表于 2015-03-13 09:14 |只看该作者
  1. awk '{if($2<1980)next;for(i=3;i<NF;i++){len=length($i);printf substr($i,1,len-2)"\t"substr($i,len-2,2)"\t"}printf "\n"}' file
复制代码
  1. 8       80      20      00      21      10
  2. 8       80      17      70      18      80
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP