| 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, magnetlinkfrom lxml import htmlfrom operator import itemgetterfrom searx.url_utils import quote, urljoinurl = 'http://www.seedpeer.eu/'search_url = url + 'search/{search_term}/7/{page_no}.html'# specific xpath variablestorrent_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-requestdef request(query, params):    params['url'] = search_url.format(search_term=quote(query),                                      page_no=params['pageno'] - 1)    return params# get response from search-requestdef 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)
 |