wordnik.py 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. """Wordnik (general)"""
  3. from lxml.html import fromstring
  4. from searx.utils import extract_text
  5. from searx.result_types import EngineResults
  6. # about
  7. about = {
  8. "website": 'https://www.wordnik.com',
  9. "wikidata_id": 'Q8034401',
  10. "official_api_documentation": None,
  11. "use_official_api": False,
  12. "require_api_key": False,
  13. "results": 'HTML',
  14. }
  15. categories = ['dictionaries', 'define']
  16. paging = False
  17. def request(query, params):
  18. params['url'] = f"https://www.wordnik.com/words/{query}"
  19. return params
  20. def response(resp):
  21. results = EngineResults()
  22. dom = fromstring(resp.text)
  23. for src in dom.xpath('//*[@id="define"]//h3[@class="source"]'):
  24. item = results.types.Translations.Item(text="")
  25. for def_item in src.xpath('following-sibling::ul[1]/li'):
  26. def_abbr = extract_text(def_item.xpath('.//abbr')).strip()
  27. def_text = extract_text(def_item).strip()
  28. if def_abbr:
  29. def_text = def_text[len(def_abbr) :].strip()
  30. # use first result as summary
  31. if not item.text:
  32. item.text = def_text
  33. item.definitions.append(def_text)
  34. results.add(results.types.Translations(translations=[item], url=resp.search_params["url"]))
  35. return results