Sto cercando di ottenere alcuni risultati da UniProt, che è un database di proteine (i dettagli non sono importanti). Sto cercando di utilizzare alcuni script che si traducono da un tipo di ID a un altro. Sono stato in grado di farlo manualmente sul browser, ma non potevo farlo in Python.Come posso parlare con UniProt su HTTP in Python?
In http://www.uniprot.org/faq/28 ci sono alcuni esempi di script. Ho provato il Perl e sembra funzionare, quindi il problema sono i miei tentativi Python. L'(di lavoro) script è:
## tool_example.pl ##
use strict;
use warnings;
use LWP::UserAgent;
my $base = 'http://www.uniprot.org';
my $tool = 'mapping';
my $params = {
from => 'ACC', to => 'P_REFSEQ_AC', format => 'tab',
query => 'P13368 P20806 Q9UM73 P97793 Q17192'
};
my $agent = LWP::UserAgent->new;
push @{$agent->requests_redirectable}, 'POST';
print STDERR "Submitting...\n";
my $response = $agent->post("$base/$tool/", $params);
while (my $wait = $response->header('Retry-After')) {
print STDERR "Waiting ($wait)...\n";
sleep $wait;
print STDERR "Checking...\n";
$response = $agent->get($response->base);
}
$response->is_success ?
print $response->content :
die 'Failed, got ' . $response->status_line .
' for ' . $response->request->uri . "\n";
Le mie domande sono:
1) Come farlo in Python?
2) Sarò in grado di "ridimensionare" in modo massiccio (ad esempio, utilizzare molte voci nel campo query)?
aggiungere il vostro codice di pitone tentativo – nosklo
era praticamente aprendo lo stesso indirizzo come vorrei nel browser, con urllib2.urlopen. –