| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 | 
							- #  Seedpeer (Videos, Music, Files)
 
- #
 
- # @website     http://seedpeer.eu
 
- # @provide-api no (nothing found)
 
- #
 
- # @using-api   no
 
- # @results     HTML (using search portal)
 
- # @stable      yes (HTML can change)
 
- # @parse       url, title, content, seed, leech, magnetlink
 
- from lxml import html
 
- from operator import itemgetter
 
- from searx.url_utils import quote, urljoin
 
- url = 'http://www.seedpeer.eu/'
 
- search_url = url + 'search/{search_term}/7/{page_no}.html'
 
- # specific xpath variables
 
- torrent_xpath = '//*[@id="body"]/center/center/table[2]/tr/td/a'
 
- alternative_torrent_xpath = '//*[@id="body"]/center/center/table[1]/tr/td/a'
 
- title_xpath = '//*[@id="body"]/center/center/table[2]/tr/td/a/text()'
 
- alternative_title_xpath = '//*[@id="body"]/center/center/table/tr/td/a'
 
- seeds_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[4]/font/text()'
 
- alternative_seeds_xpath = '//*[@id="body"]/center/center/table/tr/td[4]/font/text()'
 
- peers_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[5]/font/text()'
 
- alternative_peers_xpath = '//*[@id="body"]/center/center/table/tr/td[5]/font/text()'
 
- age_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[2]/text()'
 
- alternative_age_xpath = '//*[@id="body"]/center/center/table/tr/td[2]/text()'
 
- size_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[3]/text()'
 
- alternative_size_xpath = '//*[@id="body"]/center/center/table/tr/td[3]/text()'
 
- # do search-request
 
- def request(query, params):
 
-     params['url'] = search_url.format(search_term=quote(query),
 
-                                       page_no=params['pageno'] - 1)
 
-     return params
 
- # get response from search-request
 
- def response(resp):
 
-     results = []
 
-     dom = html.fromstring(resp.text)
 
-     torrent_links = dom.xpath(torrent_xpath)
 
-     if len(torrent_links) > 0:
 
-         seeds = dom.xpath(seeds_xpath)
 
-         peers = dom.xpath(peers_xpath)
 
-         titles = dom.xpath(title_xpath)
 
-         sizes = dom.xpath(size_xpath)
 
-         ages = dom.xpath(age_xpath)
 
-     else:  # under ~5 results uses a different xpath
 
-         torrent_links = dom.xpath(alternative_torrent_xpath)
 
-         seeds = dom.xpath(alternative_seeds_xpath)
 
-         peers = dom.xpath(alternative_peers_xpath)
 
-         titles = dom.xpath(alternative_title_xpath)
 
-         sizes = dom.xpath(alternative_size_xpath)
 
-         ages = dom.xpath(alternative_age_xpath)
 
-     # return empty array if nothing is found
 
-     if not torrent_links:
 
-         return []
 
-     # parse results
 
-     for index, result in enumerate(torrent_links):
 
-         link = result.attrib.get('href')
 
-         href = urljoin(url, link)
 
-         results.append({'url': href,
 
-                         'title': titles[index].text_content(),
 
-                         'content': '{}, {}'.format(sizes[index], ages[index]),
 
-                         'seed': seeds[index],
 
-                         'leech': peers[index],
 
-                         'template': 'torrent.html'})
 
-     # return results sorted by seeder
 
-     return sorted(results, key=itemgetter('seed'), reverse=True)
 
 
  |