我有一個帶有GI號碼的文件,想從ncbi獲得FASTA
序列。urllib2.HTTPError Python
from Bio import Entrez
import time
Entrez.email ="[email protected]"
f = open("C:\\bioinformatics\\gilist.txt")
for line in iter(f):
handle = Entrez.efetch(db="nucleotide", id=line, retmode="xml")
records = Entrez.read(handle)
print ">GI "+line.rstrip()+" "+records[0]["GBSeq_primary-accession"]+" "+records[0]["GBSeq_definition"]+"\n"+records[0]["GBSeq_sequence"]
time.sleep(1) # to make sure not many requests go per second to ncbi
f.close()
這個腳本運行良好,但在幾個序列後突然出現這個錯誤信息。
Traceback (most recent call last):
File "C:/Users/Ankur/PycharmProjects/ncbiseq/getncbiSeq.py", line 7, in <module>
handle = Entrez.efetch(db="nucleotide", id=line, retmode="xml")
File "C:\Python27\lib\site-packages\Bio\Entrez\__init__.py", line 139, in efetch
return _open(cgi, variables)
File "C:\Python27\lib\site-packages\Bio\Entrez\__init__.py", line 455, in _open
raise exception
urllib2.HTTPError: HTTP Error 500: Internal Server Error
我當然可以用http://www.ncbi.nlm.nih.gov/sites/batchentrez
但我想創建一個管道,並會喜歡的東西自動化。
如何防止NCBI從「踢我出去」