forked from jdrudolph/uniprot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuniprot.py
executable file
·81 lines (66 loc) · 2.01 KB
/
uniprot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
"""
uniprot python interface
to access the uniprot database
available services:
map
retrieve
"""
import requests
import sys, argparse
url = 'http://www.uniprot.org/'
def _retrieve(query, format='txt'):
"""_retrieve is not meant for use with the python interface, use `retrieve`
instead"""
tool = 'batch/'
query = list(set(query.split()))
queries = [query[i:i+100] for i in xrange(0, len(query), 100)]
data = {'format':format}
responses = [requests.post(url + tool, data=data, files={'file':' '.join(query)}) for query in queries]
page = ''.join([response.text for response in responses])
return page
def retrieve(ids, format='txt'):
""" request entries by uniprot acc using batch retrieval
Args:
query: list of ids to retrieve
format: txt by default
Help:
possible formats:
txt, xml, rdf, fasta, gff"""
if type(ids) is not list:
ids = [ids]
return _retrieve(' '.join(ids), format)
def _map(query, f, t, format='tab'):
""" _map is not meant for use with the python interface, use `map` instead
"""
tool = 'mapping/'
data = {
'from':f,
'to':t,
'format':format,
'query':query
}
response = requests.post(url + tool, data=data)
page = response.text
return page
def map(ids, f, t, format='tab'):
""" map a list of ids from one format onto another using uniprots mapping api
Args:
query: id or list of ids to be mapped
f: from ACC | P_ENTREZGENEID | ...
t: to ...
format: tab by default
Help:
for a list of all possible mappings visit
'http://www.uniprot.org/faq/28'
"""
if type(ids) is not list:
ids = [ids]
page = _map(' '.join(ids), f, t, format)
result = dict()
for row in page.splitlines()[1:]:
key, value = row.split('\t')
if key in result:
result[key].add(value)
else:
result[key] = set([value])
return result