logo

searx

My custom branche(s) on searx, a meta-search engine git clone https://hacktivis.me/git/searx.git

1337x.py (1394B)


  1. from lxml import html
  2. from searx.engines.xpath import extract_text
  3. from searx.utils import get_torrent_size
  4. from searx.url_utils import quote, urljoin
  5. url = 'https://1337x.to/'
  6. search_url = url + 'search/{search_term}/{pageno}/'
  7. categories = ['videos']
  8. paging = True
  9. def request(query, params):
  10. params['url'] = search_url.format(search_term=quote(query), pageno=params['pageno'])
  11. return params
  12. def response(resp):
  13. results = []
  14. dom = html.fromstring(resp.text)
  15. for result in dom.xpath('//table[contains(@class, "table-list")]/tbody//tr'):
  16. href = urljoin(url, result.xpath('./td[contains(@class, "name")]/a[2]/@href')[0])
  17. title = extract_text(result.xpath('./td[contains(@class, "name")]/a[2]'))
  18. seed = extract_text(result.xpath('.//td[contains(@class, "seeds")]'))
  19. leech = extract_text(result.xpath('.//td[contains(@class, "leeches")]'))
  20. filesize_info = extract_text(result.xpath('.//td[contains(@class, "size")]/text()'))
  21. filesize, filesize_multiplier = filesize_info.split()
  22. filesize = get_torrent_size(filesize, filesize_multiplier)
  23. results.append({'url': href,
  24. 'title': title,
  25. 'seed': seed,
  26. 'leech': leech,
  27. 'filesize': filesize,
  28. 'template': 'torrent.html'})
  29. return results