Próbuję uzyskać wyniki z UniProt, która jest bazą danych białek (szczegóły nie są ważne). Próbuję użyć skryptu, który przekłada się z jednego rodzaju identyfikatora na inny. Mogłem to zrobić ręcznie w przeglądarce, ale nie mogłem tego zrobić w Pythonie.Jak mogę rozmawiać z UniProt przez HTTP w Pythonie?
W http://www.uniprot.org/faq/28 jest kilka przykładowych skryptów. Próbowałem Perla i wygląda na to, że działa, więc problemem są moje próby w Pythonie. The (roboczy) skrypt jest:
## 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";
moje pytania są następujące:
1) W jaki sposób można to zrobić w Pythonie?
2) Czy będę w stanie znacząco "skalować" to (tj. Użyć wielu wpisów w polu zapytania)?
dodaj swój kod Pythona próba – nosklo
To dość dużo otwierając tym samym adresem co bym w przeglądarce, z urllib2.urlopen. –