免费注册 查看新帖 |

Chinaunix

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

请教请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-12 13:25 |只看该作者 |倒序浏览
文件file3:
10/05766798607,11/20050325191329,29/0.1,14/05766798607
10/05767158557,11/20050325191329,29/0.08,14/05767158557

文件b:
05766798607
05766798608
05766798609

希望查找出file3中存在b的记录输出,file3中记录以逗号分隔为准。

awk 'BEGIN{RS=",";FS="/"}NR==FNR{a[$1]=$1}NR>FNR{if($2 in a){print $2}' b file3
出不来结果,和RS=","这个有关系,具体原因请教各位?

而且怎么写才能达到要求?

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
2 [报告]
发表于 2011-12-12 13:32 |只看该作者
回复 1# SimpleLittle

不要改变RS,只设置FS
    FS="[,/]"

论坛徽章:
0
3 [报告]
发表于 2011-12-12 13:33 |只看该作者
“希望查找出file3中存在b的记录输出,file3中记录以逗号分隔为准”
什么意思?

10/05766798607,11/20050325191329,29/0.1,14/05766798607  是一个记录
还是
10/05766798607 是一个记录?

论坛徽章:
9
2015亚冠之阿尔纳斯尔
日期:2015-09-10 16:21:162015亚冠之塔什干火车头
日期:2015-07-01 16:23:022015年亚洲杯之巴勒斯坦
日期:2015-04-20 17:19:46子鼠
日期:2014-11-13 09:51:26未羊
日期:2014-08-28 18:13:36技术图书徽章
日期:2014-02-21 09:30:15酉鸡
日期:2014-01-14 11:12:49天蝎座
日期:2013-12-09 17:56:53平安夜徽章
日期:2015-12-26 00:06:30
4 [报告]
发表于 2011-12-12 13:35 |只看该作者
grep -Ff b file3

论坛徽章:
0
5 [报告]
发表于 2011-12-12 13:39 |只看该作者
回复 3# Linux_rocking


    10/05766798607 是一个记录

论坛徽章:
0
6 [报告]
发表于 2011-12-12 13:44 |只看该作者
awk 'BEGIN{RS=",|\n";FS="/"}NR==FNR{a[$1=$1]}NR>FNR{if($2 in a)print $2}' b file3

论坛徽章:
0
7 [报告]
发表于 2011-12-12 13:45 |只看该作者
awk 'BEGIN{FS="[,;/]"}NR==FNR{a[$1]=$1}NR>FNR{print $2}' b file3

这样获取的FILE3的$2是
05766798607
05767158557


匹配的只是这两个值,我需要能匹配到后面的值

10/05766798607,11/20050325191329,29/0.1,14/05766798607
10/05767158557,11/20050325191329,29/0.08,14/05767158557

就是说,如果我FILE3包含4列

10/05766798607,11/20050325191329,29/0.1,14/05766798607
10/05767158557,11/20050325191329,29/0.08,14/05767158557
10/05766798607,11/20050325191329,29/0.1,14/05766798608
10/05767158557,11/20050325191329,29/0.08,14/05766798609

程序应该是匹配出1,3,4行,而不是地1行

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
8 [报告]
发表于 2011-12-12 13:53 |只看该作者
回复 7# SimpleLittle
awk 'BEGIN{FS=",";}NR==FNR{a[$1];next}{for(i=1;i<=NF;i++){if(gensub(/.*\//,"",1,$i) in a) print $i}}' b file3

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
9 [报告]
发表于 2011-12-12 13:55 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
10 [报告]
发表于 2011-12-12 14:01 |只看该作者
awk -vRS="[,\n]" -F'/' 'NR==FNR{a[$1];next}{if($2 in a) print $0}' b file3
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP