1337x.py 1.4 KB

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