12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
-
-
-
-
-
-
-
-
-
-
- from urllib import urlencode
- from lxml import etree
- from searx.engines.xpath import extract_text
- from searx.utils import html_to_text
-
-
- base_url = 'http://api.wolframalpha.com/v2/query'
- search_url = base_url + '?appid={api_key}&{query}&format=plaintext'
- site_url = 'http://wolframalpha.com/input/?{query}'
-
-
-
-
-
-
- def request(query, params):
- params['url'] = search_url.format(query=urlencode({'input': query}),
- api_key=api_key)
-
-
- global my_query
- my_query = query
-
- return params
-
-
- def replace_pua_chars(text):
- pua_chars = { u'\uf74c': 'd',
- u'\uf74d': u'\u212f',
- u'\uf74e': 'i',
- u'\uf7d9': '=' }
-
- for k, v in pua_chars.iteritems():
- text = text.replace(k, v)
-
- return text
-
-
- def response(resp):
- results = []
-
- search_results = etree.XML(resp.content)
-
-
- if search_results.xpath('/queryresult[attribute::success="false"]'):
- return []
-
-
- result = search_results.xpath('//pod[attribute::primary="true"]/subpod/plaintext')[0].text
- result = replace_pua_chars(result)
-
-
- result_url = site_url.format(query=urlencode({'i': my_query}))
-
-
- results.append({'url': result_url,
- 'title': result})
-
-
- return results
|