[Bioperl-l] Bio::SeqIO::genbank

Wayne Davis m.wayne.davis at gmail.com
Thu Apr 8 13:07:17 EDT 2010


I'm not a reader or the bioperl list, but this might be a format to
address a question that I'm dealing with:

I have a parser (non-Perl) that is having some trouble with "genbank"
formatted files.
The troublesome files are from from another source that uses bioperl
to write their files with Bio::SeqIO::genbank


Trouble is that the molecule type (in the LOCUS line) they are writing
is free text, as allowed by the Bioperl  Bio::SeqIO::genbank module:

	    $temp_line = sprintf ("%-12s%-15s%13s %s%4s%-8s%-8s %3s %-s",
				  'LOCUS', $seq->id(),$len,
				  (lc($alpha) eq 'protein') ? ('aa','', '') :
				  ('bp', '',$mol),$circular,
				  $div,$date);


however the genbank file definition at
ftp://ftp.ncbi.nih.gov/genbank/gbrel.txt

section 3.4.4 specifies the format for the LOCUS line:
in the table of column positions they specify a limited vocabulary of
fixed width:
"48-53      NA, DNA, RNA, tRNA (transfer RNA), rRNA (ribosomal RNA),
          mRNA (messenger RNA), uRNA (small nuclear RNA), snRNA,
          snoRNA. Left justified."


which to me strongly suggests that the genbank file format requires a
fixed vocabulary for molecule type.

Seems that in Bio::SeqIO::genbank at
	if( !$seq->can('molecule') || ! defined ($mol = $seq->molecule()) ) {
	    $mol =  $alpha || 'DNA';
	}

if $mol is not in the fixed list of genbank molecule types it should
be set to the default value of 'DNA', or some other smarter way of
forcing the molecule type into the fixed vocabulary would be a help.

Thanks for any replies.



-- 
Wayne Davis

Department of Biology
University of Utah
257 South 1400 East
Salt Lake City, UT 84112-0840
(801) 585-3692


More information about the Bioperl-l mailing list