| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 | # SPDX-License-Identifier: AGPL-3.0-or-later""" eTools (Web)"""from lxml import htmlfrom urllib.parse import quotefrom searx.utils import extract_text, eval_xpath# aboutabout = {    "website": 'https://www.etools.ch',    "wikidata_id": None,    "official_api_documentation": None,    "use_official_api": False,    "require_api_key": False,    "results": 'HTML',}categories = ['general']paging = Falsesafesearch = Truebase_url = 'https://www.etools.ch'search_path = '/searchAdvancedSubmit.do'\    '?query={search_term}'\    '&pageResults=20'\    '&safeSearch={safesearch}'def request(query, params):    if params['safesearch']:        safesearch = 'true'    else:        safesearch = 'false'    params['url'] = base_url + search_path.format(search_term=quote(query), safesearch=safesearch)    return paramsdef response(resp):    results = []    dom = html.fromstring(resp.text)    for result in eval_xpath(dom, '//table[@class="result"]//td[@class="record"]'):        url = eval_xpath(result, './a/@href')[0]        title = extract_text(eval_xpath(result, './a//text()'))        content = extract_text(eval_xpath(result, './/div[@class="text"]//text()'))        results.append({'url': url,                        'title': title,                        'content': content})    return results
 |