[Bioperl-l] extracting ORGANISM line from genbank file

Anna Kostikova geoeco at rambler.ru
Tue Aug 25 03:01:24 EDT 2009


Hi Rohit,

Thanks a lot for your comments, it actually worked well, but in  fact i 
only want to extract species names as I want to have it in a separate 
file together with a fasta file with sequences.
So, thanks a lot again!

Anna

* Rohit Ghai <ghai.rohit at gmail.com> [Mon, 24 Aug 2009 14:53:03 +0200]:
> hi
>
> I think you forgot to add the "seq" in the builder.. thats why the 
file
> is
> empty.
> Also, the species name, though being parsed, is nowhere in the output.
> Here's a version
> using fasta output that you can probably customize further. This also
> takes
> the full
> name of the organism and adds to the description line in the output.
>
> use strict;
> use Bio::SeqIO;
> use Bio::Seq::SeqBuilder;
>
> my $usage = "genbank_to_fasta_cleaning.pl infile outfile \n";
>        my $infile = shift or die $usage;
>        my $infileformat = 'Genbank' ;
>        my $outfile = shift or die $usage;
>        my $outfileformat = 'fasta';
>        my $i = 0;
>
>        my $seq_in = Bio::SeqIO->new('-file' => "<$infile",
>                                     '-format' => $infileformat);
>
>             my $seq_out = Bio::SeqIO->new('-file' => ">$outfile",
>                                      '-format' => $outfileformat);
>
>             my $builder = $seq_in->sequence_builder();
>
>             $builder->want_none();
>
> $builder->add_wanted_slot('display_id','species','seq','description');
>
>  while(my $seq = $seq_in->next_seq()) {
>
>      my $desc = $seq->description();
>      my $species_string = $seq->species()->binomial('FULL');
>     $desc = $desc . " [$species_string]";
>     $seq->description($desc);
>      $seq_out->write_seq($seq);
>  }
>
>    exit;
>
>
> On Mon, Aug 24, 2009 at 11:20 AM, Anna Kostikova <geoeco at rambler.ru>
> wrote:
>
> >
> > Dear all,
> >
> > I am trying to extract species taxonomy from ORGANISM line. In fact 
I
> only
> > need a first line under ORGANISM tag (e.i. genus + species). I 
though
> that
> > it would be possible to do with the SeqBuilder object by stating
> >
> > $builder->add_wanted_slot('display_id','species');
> >
> > the problem is, however, that I've got an empty file as a result.
> > What might be wrong with the script (see below)?
> > Thanks a lot in advance for any ideas,
> >
> > -------------------------------------------
> >
> > #!/usr/bin/perl
> > use strict;
> > use Bio::SeqIO;
> > use Bio::Seq::SeqBuilder;
> >
> > my $usage = "genbank_to_fasta_cleaning.pl infile outfile \n";
> >        my $infile = shift or die $usage;
> >        my $infileformat = 'Genbank' ;
> >        my $outfile = shift or die $usage;
> >        my $outfileformat = 'raw';
> >                 my $i = 0;
> >
> >        my $seq_in = Bio::SeqIO->new('-file' => "<$infile",
> >                                     '-format' => $infileformat);
> >
> >             my $seq_out = Bio::SeqIO->new('-file' => ">$outfile",
> >                                      '-format' => $outfileformat);
> >
> >                my $builder = $seq_in->sequence_builder();
> >
> >  $builder->want_none();
> >  $builder->add_wanted_slot('display_id','species');
> >
> >  while(my $seq = $seq_in->next_seq()) {
> >      $seq_out->write_seq($seq);
> >  }
> >
> >    exit;
> >
> > ----------------------------------------------------
> >
> > Anna
> > _______________________________________________
> > Bioperl-l mailing list
> > Bioperl-l at lists.open-bio.org
> > http://lists.open-bio.org/mailman/listinfo/bioperl-l
> >







More information about the Bioperl-l mailing list