根据一个ID列表文件来从一个fasta文件里面挑取符合要求的序列
发布时间:2020-12-15 21:10:54 所属栏目:大数据 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 #!/usr/bin/perl -w if( @ARGV != 2 ) { print "Usage: we need two filesn"; exit 0;} my $ID=shift @ARGV; my $fasta=shift @ARGV; open FH1,"$ID"
|
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 #!/usr/bin/perl -w
if( @ARGV != 2 )
{
print "Usage: we need two filesn";
exit 0;
}
my $ID=shift @ARGV;
my $fasta=shift @ARGV;
open FH1,"<$ID" or die "can not open the file,$!";
while (<FH1>)
{
chomp;
$hash{$_}=1;
}
#读取第一个参数,ID列表,每一行的ID都扫描进去hash表
open FH2,"$fasta" or die "can not open the file,$!";
while(defined($line=<FH2>))
{
chomp $line;
if($line =~ />/)
{
$key = (split /s/,$line)[0];
$key =~ s/>//g;
$flag = exists $hash{$key}?1:0;
}#这个flag是用来控制这个标记下面的序列是否输出
print $line."n" if $flag == 0;
}
以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
