[Bioperl-l] GI to taxonomy
Fields, Christopher J
cjfields at illinois.edu
Mon Sep 16 15:14:10 UTC 2013
Just tested it and it seems to work fine (passes tests). I committed a change to both the master and 1.6 branches.
chris
On Sep 16, 2013, at 9:58 AM, Bernd W <bernd.web at gmail.com> wrote:
> Hi Chris, Brian,
>
> Indeed, according to NCBI docs
> (http://www.ncbi.nlm.nih.gov/books/NBK25500/), the base URL should be:
>
> http://eutils.ncbi.nlm.nih.gov/entrez/eutils/
>
>
> Example seach:
> http://eutils.ncbi.nlm.nih.gov/entrez/eutils/esearch.fcgi?db=pubmed&term=science[journal]+AND+breast+cancer+AND+2008[pdat]
>
>
> Kind regards,
> Bernd
>
> On Mon, Sep 16, 2013 at 4:39 PM, Fields, Christopher J
> <cjfields at illinois.edu> wrote:
>> That's possible; there are various eutils interfaces scattered throughout bioperl, so it's possible some haven't been updated to the most recent URL. Brian, does a modified URL work?
>>
>> chris
>>
>> On Sep 16, 2013, at 8:08 AM, Brian Osborne <bosborne11 at verizon.net> wrote:
>>
>>> Chris,
>>>
>>> Bio::DB::Taxonomy::entrez uses this URL by default:
>>>
>>> http://www.ncbi.nih.gov/entrez/eutils/
>>>
>>> Should it be using this one?
>>>
>>> http://eutils.ncbi.nlm.nih.gov/entrez/eutils/
>>>
>>> Brian O.
>>>
>>> On Sep 13, 2013, at 4:06 AM, Alexey Morozov <alexeymorozov1991 at gmail.com> wrote:
>>>
>>>> Dear colleagues,
>>>> I have a bunch of fasta genomes annotated only by their GI numbers, and
>>>> need to get a taxonomy for all of them. So I rewrote get_tree method from
>>>> Bio::DB::Taxonomy:
>>>>
>>>> 12 open GIS, GI_FILE;
>>>> 13 my $tax_db=Bio::DB::Taxonomy->new(source=>'entrez');
>>>> 14 my $tree;
>>>> 15 while (<GIS>)
>>>> 16 {
>>>> 17 print "Requesting data for GI $_\n";
>>>> 18 my $taxon=$tax_db->get_taxon(-gi=>"$_",-db=>'nucleotide');
>>>> 19 if ($@){die $@;}#Catch exception and die, just in case
>>>> 20 # or die "Cannot get taxonomy data for GI$_:$!\n";
>>>> 21 if ($tree)
>>>> 22 {
>>>> 23 $tree->merge_lineage($taxon);
>>>> 24 }else
>>>> 25 {
>>>> 26 $tree=Bio::Tree::Tree->new(-node=>$taxon);
>>>> 27 }
>>>> 28 }
>>>>
>>>> This (line 18) way to invoke Bio::DB::Taxonomy->get_taxon is documented and
>>>> I expect to get taxon objects. Yet all I get is
>>>>
>>>>
>>>> --------------------- WARNING ---------------------
>>>> MSG: Must have provided a valid HASHref for -params
>>>> ---------------------------------------------------
>>>> Requesting data for GI 15604717
>>>>
>>>>
>>>> ------------- EXCEPTION: Bio::Root::Exception -------------
>>>> MSG: Can't query website: 400 URL must be absolute
>>>> STACK: Error::throw
>>>> STACK: Bio::Root::Root::throw /usr/share/perl5/Bio/Root/Root.pm:472
>>>> STACK: Bio::DB::Taxonomy::entrez::get_taxon
>>>> /usr/share/perl5/Bio/DB/Taxonomy/entrez.pm:247
>>>> STACK: ./get_tax:18
>>>> -----------------------------------------------------------
>>>>
>>>> Directly using Bio::DB::Taxonomy::entrez doesn't help, GI numbers load OK,
>>>> so I have no clue what happened.
>>>> Need help.
>>>> --
>>>> Alexey Morozov,
>>>> LIN SB RAS, bioinformatics group.
>>>> Irkutsk, Russia.
>>>> _______________________________________________
>>>> Bioperl-l mailing list
>>>> Bioperl-l at lists.open-bio.org
>>>> http://lists.open-bio.org/mailman/listinfo/bioperl-l
>>>
>>>
>>> _______________________________________________
>>> Bioperl-l mailing list
>>> Bioperl-l at lists.open-bio.org
>>> http://lists.open-bio.org/mailman/listinfo/bioperl-l
>>
>>
>> _______________________________________________
>> 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