免费注册 查看新帖 |

Chinaunix

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

关于数值对比大小 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-27 15:30 |只看该作者 |倒序浏览
a文件:
ID           数值
250026  10
250131  30
250213  40
250166  30
250226  60
250245  30
250220  900
250299  99
250296  900
250298  30
250301  100

b文件:
ID           数值
250026  50
250131  30
250213  40
250166  30
250226  60
250245  30
250220  50
250299  99
250298  30
250301  700


两个文件,根据ID相同,找出相同ID,对比数值,找出a数值大于或等于b数值的ID。

请教各大侠。谢谢。


另外两个文件里的ID不一定全相同,a里有的ID b里不一定有。b里有的a也不定有。

论坛徽章:
0
2 [报告]
发表于 2008-10-27 15:48 |只看该作者
如果是数据库的话就方便了,直接用sql语句就可以完成了。

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
3 [报告]
发表于 2008-10-27 15:51 |只看该作者
  1. awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>$2{print $1}' filea fileb
复制代码

论坛徽章:
0
4 [报告]
发表于 2008-10-27 16:04 |只看该作者
原帖由 ly5066113 于 2008-10-27 15:51 发表
awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>$2{print $1}' filea fileb


厉害。运行了下好像是对的

论坛徽章:
0
5 [报告]
发表于 2008-10-27 16:14 |只看该作者
[root@localhost temp]# cat a
12345    3
12      6
[root@localhost temp]# cat b
12345    3
12      6
[root@localhost temp]# awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>$2{print $1}'  a b
[root@localhost temp]#


好像不对哦,结果怎么是空的呢?

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
6 [报告]
发表于 2008-10-27 16:29 |只看该作者
原帖由 于仁洁 于 2008-10-27 16:14 发表
[root@localhost temp]# cat a
12345    3
12      6
[root@localhost temp]# cat b
12345    3
12      6
[root@localhost temp]# awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>$2{print $1}'  a b
[root@loc ...


awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>=$2{print $1}'  a b

评分

参与人数 1可用积分 +5 收起 理由
枫影谁用了 + 5

查看全部评分

论坛徽章:
1
白银圣斗士
日期:2015-11-23 08:33:04
7 [报告]
发表于 2008-10-27 16:36 |只看该作者
加点分,顺便来学习下。

能不能解释下哇

[ 本帖最后由 枫影谁用了 于 2008-10-27 16:39 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
8 [报告]
发表于 2008-10-27 16:46 |只看该作者
原帖由 枫影谁用了 于 2008-10-27 16:36 发表
加点分,顺便来学习下。

能不能解释下哇


谢了,呵呵。

awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>=$2{print $1}'  a b
awk操作2个文件的典型例子。
NR==FNR 操作第一个文件,a[$1]=$2 以$1为key,$2为value,建立hash数组a
NR>FNR 操作第二个文件,a[$1]>=$2{print $1} 如果$1对应在a文件中的值大于等于$2,则打印$1。

论坛徽章:
0
9 [报告]
发表于 2008-10-27 16:49 |只看该作者
  1. join a b | awk '$2>=$3{print $1}'
复制代码

论坛徽章:
0
10 [报告]
发表于 2008-10-27 17:11 |只看该作者
原帖由 seeLnd 于 2008-10-27 16:49 发表
join a b | awk '$2>=$3{print $1}'


这个可以,但是只能处理4位数的ID,在join连接的时候就没有。

当有ID大于5位数的时候就处理不到。

[root@localhost temp]# awk 'NR==FNR{a[$1]=$2}NR>FNR&&a[$1]>=$2{print $1}' a b
7628
8827
9279
9506
9525
9735
9941
9993
10017
10326
10401
10611
200003
200062
250177
250157
250213
[root@localhost temp]# join  a b |awk '$2>=$3{print $1}'
7628
8827
9279
9506
9525
9735
9941
9993
[root@localhost temp]#
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP