加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

使用Unix / Bash,我如何制作查找表?

发布时间:2020-12-15 16:59:42 所属栏目:安全 来源:网络整理
导读:所以我有一个基因名称和探测ID的.txt列表,originalFile.txt,如下所示: GENE_ID PROBE_ID10111 1987310112 284,1998310113 187 此文本文件中有大约30,000行.我想在第二列中创建一个没有逗号的新文本文件,例如: GENE_ID PROBE_ID10111 1987310112 28410112 1
所以我有一个基因名称和探测ID的.txt列表,originalFile.txt,如下所示:
GENE_ID PROBE_ID
10111   19873
10112   284,19983
10113   187

此文本文件中有大约30,000行.我想在第二列中创建一个没有逗号的新文本文件,例如:

GENE_ID PROBE_ID
10111   19873
10112   284
10112   19983
10113   187

…而且,我希望所有的PROBE_ID来自另一个文本文件probes.txt,它看起来像:

19873
284
187

…这样我就可以制作一个看起来如下的finalProduct.txt文件:

GENE_ID PROBE_ID
10111   19873
10112   284
10113   187

如果我想手动输入每行probe.txt,我想我可以通过以下方式实现这个结果:

awk -F"/t" '{for(i=1;i<=NF;i++){if ($i ~ /probeID#/){print $i}}}' myGenes > test.txt

但是,当然,这不会将逗号分隔的探测ID放在不同的行上,我必须手动输入数千个probeID中的每一个.

有没有人有任何提示或更好的建议?
谢谢!

编辑清晰度
所以我认为我要问的是两个步骤.我想使用probe.txt获取originalFile.txt并最终生成finalProduct.txt.这有两个步骤:

对于probe.txt中列出的每个探测器,查看它是否存在于originalFile.txt中;
如果探针确实存在,则打印仅包含探针和相应GENE_ID的行.

或者您可以将它视为使用probes.txt在originalFile.txt上的过滤器之间的某种连接,其中输出文件将PROBE_ID列作为probes.txt中的探测器和来自originalFile.txt的相应GENE_ID.

或者你可以把它想象成:
1.制作一个中间文件,其中GENE_ID和PROBE_ID之间存在多对一的对应关系
2.删除PROBE_ID与probes.txt中的条目不对应的该中间文件的所有行

编辑2
目前正试图重新利用this – 尚无结果,但也许链接将有所帮助.

如果probes.txt足够小以至于它适合内存,您可以尝试以下awk脚本:
BEGIN {
    OFS="t";
    # this is to handle the given input that has spaces after the comma
    # and tabs between gene and probes
    FS="[t,]+";
    # load probes into an array
    while ((getline probe < "probes.txt") > 0) {
        probes[probe] = 1;
    }
    close ("probes.txt");
}

{
    # for each probe,check if it's in the array
    # and skip it if not
    for (i=2; i <= NF; i++) {
        if (probes[$i] == 1) {
            print $1,$i;
        }
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读