|
@@ -11,9 +11,11 @@
|
11
|
11
|
More info on api: https://www.ncbi.nlm.nih.gov/books/NBK25501/
|
12
|
12
|
"""
|
13
|
13
|
|
|
14
|
+from flask_babel import gettext
|
14
|
15
|
from lxml import etree
|
15
|
16
|
from datetime import datetime
|
16
|
|
-from searx.url_utils import urlencode, urlopen
|
|
17
|
+from searx.url_utils import urlencode
|
|
18
|
+from searx.poolrequests import get
|
17
|
19
|
|
18
|
20
|
|
19
|
21
|
categories = ['science']
|
|
@@ -46,12 +48,7 @@ def response(resp):
|
46
|
48
|
pubmed_retrieve_api_url = 'https://eutils.ncbi.nlm.nih.gov/entrez/eutils/efetch.fcgi?'\
|
47
|
49
|
+ 'db=pubmed&retmode=xml&id={pmids_string}'
|
48
|
50
|
|
49
|
|
- # handle Python2 vs Python3 management of bytes and strings
|
50
|
|
- try:
|
51
|
|
- pmids_results = etree.XML(resp.text.encode('utf-8'))
|
52
|
|
- except AttributeError:
|
53
|
|
- pmids_results = etree.XML(resp.text)
|
54
|
|
-
|
|
51
|
+ pmids_results = etree.XML(resp.content)
|
55
|
52
|
pmids = pmids_results.xpath('//eSearchResult/IdList/Id')
|
56
|
53
|
pmids_string = ''
|
57
|
54
|
|
|
@@ -62,7 +59,7 @@ def response(resp):
|
62
|
59
|
|
63
|
60
|
retrieve_url_encoded = pubmed_retrieve_api_url.format(**retrieve_notice_args)
|
64
|
61
|
|
65
|
|
- search_results_xml = urlopen(retrieve_url_encoded).read()
|
|
62
|
+ search_results_xml = get(retrieve_url_encoded).content
|
66
|
63
|
search_results = etree.XML(search_results_xml).xpath('//PubmedArticleSet/PubmedArticle/MedlineCitation')
|
67
|
64
|
|
68
|
65
|
for entry in search_results:
|
|
@@ -74,12 +71,12 @@ def response(resp):
|
74
|
71
|
try:
|
75
|
72
|
content = entry.xpath('.//Abstract/AbstractText')[0].text
|
76
|
73
|
except:
|
77
|
|
- content = 'No abstract is available for this publication.'
|
|
74
|
+ content = gettext('No abstract is available for this publication.')
|
78
|
75
|
|
79
|
76
|
# If a doi is available, add it to the snipppet
|
80
|
77
|
try:
|
81
|
78
|
doi = entry.xpath('.//ELocationID[@EIdType="doi"]')[0].text
|
82
|
|
- content = 'DOI: ' + doi + ' Abstract: ' + content
|
|
79
|
+ content = 'DOI: {doi} Abstract: {content}'.format(doi=doi, content=content)
|
83
|
80
|
except:
|
84
|
81
|
pass
|
85
|
82
|
|