qwant.py 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. """
  2. Qwant (Web, Images, News, Social)
  3. @website https://qwant.com/
  4. @provide-api not officially (https://api.qwant.com/api/search/)
  5. @using-api yes
  6. @results JSON
  7. @stable yes
  8. @parse url, title, content
  9. """
  10. from urllib import urlencode
  11. from json import loads
  12. from datetime import datetime
  13. # engine dependent config
  14. categories = None
  15. paging = True
  16. language_support = True
  17. category_to_keyword = {'general': 'web',
  18. 'images': 'images',
  19. 'news': 'news',
  20. 'social media': 'social'}
  21. # search-url
  22. url = 'https://api.qwant.com/api/search/{keyword}?count=10&offset={offset}&f=&{query}'
  23. # do search-request
  24. def request(query, params):
  25. offset = (params['pageno'] - 1) * 10
  26. if categories[0] and categories[0] in category_to_keyword:
  27. params['url'] = url.format(keyword=category_to_keyword[categories[0]],
  28. query=urlencode({'q': query}),
  29. offset=offset)
  30. else:
  31. params['url'] = url.format(keyword='web',
  32. query=urlencode({'q': query}),
  33. offset=offset)
  34. # add language tag if specified
  35. if params['language'] != 'all':
  36. params['url'] += '&locale=' + params['language'].lower()
  37. return params
  38. # get response from search-request
  39. def response(resp):
  40. results = []
  41. search_results = loads(resp.text)
  42. # return empty array if there are no results
  43. if 'data' not in search_results:
  44. return []
  45. data = search_results.get('data', {})
  46. res = data.get('result', {})
  47. # parse results
  48. for result in res.get('items', {}):
  49. title = result['title']
  50. res_url = result['url']
  51. content = result['desc']
  52. if category_to_keyword.get(categories[0], '') == 'web':
  53. results.append({'title': title,
  54. 'content': content,
  55. 'url': res_url})
  56. elif category_to_keyword.get(categories[0], '') == 'images':
  57. thumbnail_src = result['thumbnail']
  58. img_src = result['media']
  59. results.append({'template': 'images.html',
  60. 'url': res_url,
  61. 'title': title,
  62. 'content': '',
  63. 'thumbnail_src': thumbnail_src,
  64. 'img_src': img_src})
  65. elif (category_to_keyword.get(categories[0], '') == 'news' or
  66. category_to_keyword.get(categories[0], '') == 'social'):
  67. published_date = datetime.fromtimestamp(result['date'], None)
  68. results.append({'url': res_url,
  69. 'title': title,
  70. 'publishedDate': published_date,
  71. 'content': content})
  72. # return results
  73. return results