免费注册 查看新帖 |

Chinaunix

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

[文本处理] 两个文件匹配比较,并打印 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-07-15 16:04 |只看该作者 |倒序浏览
file1
chr2        intron          25           30          -        m
chr2        intron          46           71          -        m
chr2        intron          79           90          -        m
chr2        intron          107           130          -        m
chr3        intron          258           271          -        n
chr3        intron          279           290          -        n
chr3        intron          307           330          -        n

file2
chr2        cds        36          98          -        m
chr3        cds        246          295          -        n

大家好,虽然学习了一段数组,但水平仍然有限,期望得到大神的帮助,谢谢。我想从file1得到:
首先file1中的($1 和$6) 和 file2中的 ($1 and $6)相同, 之后 其每行的file1中的($3 和$4)若处于file2($3 and $4)的范围中,则打印出来。

期望得到的结果:
chr2        intron          46           71          -        m
chr2        intron          79           90          -        m
chr3        intron          258           271          -        n
chr3        intron          279           290          -        n

谢谢。

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
2 [报告]
发表于 2015-07-15 16:13 |只看该作者
回复 1# 海龙小知识
  1. $ awk 'NR==FNR{a[$1,$6]=$3" "$4}NR!=FNR&&a[$1,$6]{split(a[$1,$6],t);if(t[1]<$3&&$4<t[2]){print $0}}' b a
  2. chr2        intron          46           71          -        m
  3. chr2        intron          79           90          -        m
  4. chr3        intron          258           271          -        n
  5. chr3        intron          279           290          -        n
复制代码

论坛徽章:
0
3 [报告]
发表于 2015-07-15 16:19 |只看该作者
本帖最后由 海龙小知识 于 2015-07-15 16:24 编辑

看懂什么意思,但是却写不出来,这是我写的粗鄙的脚本,却运行没有结果
这是我昨天写的,不知道哪错了,求大神指点
FNR == NR { a[$1,$3,$4,$6]; next }END{ split(a,c,","); for ($6 in c[4] && $1 in c[1]) if( ($3 > c[2]) && ($4 < c[3]) ){print $0}}

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
4 [报告]
发表于 2015-07-15 16:22 |只看该作者
回复 3# 海龙小知识


    你的 $1 和$6 不是要一样, 你这里有这个?

论坛徽章:
0
5 [报告]
发表于 2015-07-15 16:25 |只看该作者
我又改了一下,大神帮忙指正一下错误,非常感谢

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2015-07-15 16:26 |只看该作者
本帖最后由 MMMIX 于 2015-07-15 16:29 编辑

回复 1# 海龙小知识

  1. FILENAME == "file2" {
  2.         c[$1,$6,3] = $3
  3.         c[$1,$6,4] = $4
  4.         next
  5. }

  6. {
  7.         if (c[$1,$6,3] <= $3 && $4 <= c[$1,$6,4]) {
  8.                 print
  9.         }
  10. }
复制代码

论坛徽章:
0
7 [报告]
发表于 2015-07-15 16:28 |只看该作者
谢谢,那个您看我写的那个什么地方出现错误了,请指正一下,谢谢。

论坛徽章:
0
8 [报告]
发表于 2015-07-15 16:30 |只看该作者
那您看我写的那个脚本,运行不出来,您看是什么问题,请帮忙指正一下,谢谢。回复 6# MMMIX


   

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
9 [报告]
发表于 2015-07-15 16:31 |只看该作者
回复 5# 海龙小知识
  1. $ awk 'FNR==NR{a[$1,$3,$4,$6];next}{for(i in a){split(i,t,SUBSEP);if(t[1]==$1&&t[4]==$6&&t[2]<$3&&$4<t[3]){print $0;break}}}' b a
  2. chr2        intron          46           71          -        m
  3. chr2        intron          79           90          -        m
  4. chr3        intron          258           271          -        n
  5. chr3        intron          279           290          -        n
复制代码
按你的意思折腾的

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
10 [报告]
发表于 2015-07-15 16:34 |只看该作者
回复 8# 海龙小知识


    1. 不应该用 END
    2. 把你最后的数组 c 打印出来看看
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP