| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 | ## Blekko (Images)## @website     https://blekko.com# @provide-api yes (inofficial)## @using-api   yes# @results     JSON# @stable      yes# @parse       url, title, img_srcfrom json import loadsfrom urllib import urlencode# engine dependent configcategories = ['images']paging = Truesafesearch = True# search-urlbase_url = 'https://blekko.com'search_url = '/api/images?{query}&c={c}'# safesearch definitionssafesearch_types = {2: '1',                    1: '',                    0: '0'}# do search-requestdef request(query, params):    c = (params['pageno'] - 1) * 48    params['url'] = base_url +\        search_url.format(query=urlencode({'q': query}),                          c=c)    if params['pageno'] != 1:        params['url'] += '&page={pageno}'.format(pageno=(params['pageno']-1))    # let Blekko know we wan't have profiling    params['cookies']['tag_lesslogging'] = '1'    # parse safesearch argument    params['cookies']['safesearch'] = safesearch_types.get(params['safesearch'], '')    return params# get response from search-requestdef response(resp):    results = []    search_results = loads(resp.text)    # return empty array if there are no results    if not search_results:        return []    for result in search_results:        # append result        results.append({'url': result['page_url'],                        'title': result['title'],                        'content': '',                        'img_src': result['url'],                        'template': 'images.html'})    # return results    return results
 |