免费注册 查看新帖 |

Chinaunix

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

[文本处理] awk 文本中所有数字除以相同的数 并筛选出符合条件的行 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-11-14 15:20 |只看该作者 |倒序浏览
本帖最后由 xunong 于 2014-11-14 16:46 编辑

文件
ID a  b  c  d
A  1  0  10  15
B  22 9  1  0
C  21 20 19 28
...

现在给所有数除以10,得到结果后,再按照同时满足a列>2 来筛选
                                                                 b   >1
                                                                 c   >1
                                                                 d  >2
                                                           最后应该只剩下C行(显示除以10之后的数)


求大神帮忙!

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2014-11-14 15:33 |只看该作者
awk '{if($1/10>2 && $2/10>1 && $3/10>1 && $4/10>2){print $0}}' file

论坛徽章:
769
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
3 [报告]
发表于 2014-11-14 15:48 |只看该作者
回复 1# xunong
  1. awk 'BEGIN{a[2]=a[5]=20;a[3]=a[4]=10} NR>1{k=1;for(i=2;i<=NF;i++)k=k&&($i>a[i])}k' i
  2. C  21 20 19 28
复制代码

论坛徽章:
9
2015亚冠之大阪钢巴
日期:2015-06-04 11:47:30丑牛
日期:2015-01-22 15:49:26巳蛇
日期:2015-01-22 10:11:18巨蟹座
日期:2014-11-20 10:55:03天蝎座
日期:2014-11-16 22:10:26处女座
日期:2014-11-16 11:01:10申猴
日期:2014-09-19 11:12:37双鱼座
日期:2014-07-25 10:09:54程序设计版块每日发帖之星
日期:2015-08-24 06:20:00
4 [报告]
发表于 2014-11-14 15:49 |只看该作者
本帖最后由 Buring__ 于 2014-11-14 15:50 编辑

回复 1# xunong
  1. awk 'NR>1{for(i=1;i++<NF;)$i=$i/10}$1>2&&$3>1&&$4>1&&$5>2' urfile
复制代码
貌似理解错了

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
5 [报告]
发表于 2014-11-14 15:53 |只看该作者
回复 1# xunong


>>  现在给所有数除以10,得到结果后,...
>>  ...满足a列>2 , b>1, c >1, d  >2
>>   最后应该只剩下C行

a列>20, b列>10, c列>10, d列>20

$ awk '$2>20 && $3>10 && $4>10 && $5>20 && NR>1' FILE
C  21 20 19 28


论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
6 [报告]
发表于 2014-11-14 16:09 |只看该作者
本帖最后由 jason680 于 2014-11-14 16:14 编辑

回复 3# Herowinter

combine your idea ...

$ awk -vd="10 2 1 1 2" 'BEGIN{split(d,a," ")}{for(n=2;n<=NF;n++)if($n/a[1]<=a[n])next}1' FILE
C  21 20 19 28

论坛徽章:
0
7 [报告]
发表于 2014-11-14 16:47 |只看该作者
貌似 问题写错了 刚改正 最后输出应该是C 2.1 2.0 1.9 2.8

论坛徽章:
769
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
8 [报告]
发表于 2014-11-14 17:23 |只看该作者
回复 6# jason680


thanks, much better now.

论坛徽章:
769
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
9 [报告]
发表于 2014-11-14 17:30 |只看该作者
回复 7# xunong

借用楼上Jason大神的
  1. awk -vd="10 2 1 1 2" 'BEGIN{split(d,a," ")}{for(n=2;n<=NF;n++)if($n/a[1]<=a[n])next;else $n=sprintf("%.1f",$n/10)}1' i
  2. C 2.1 2.0 1.9 2.8
复制代码

论坛徽章:
0
10 [报告]
发表于 2014-11-14 20:16 |只看该作者
回复 9# Herowinter
非常感谢!
又想到一个问题,如果给4列数分别除以不同的数eg:9,10,10,11,而不是统一除以10
该怎么办呢?

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP