flickr.py 937 B

123456789101112131415161718192021222324252627282930
  1. #!/usr/bin/env python
  2. from urllib import quote
  3. from lxml import html
  4. from urlparse import urljoin
  5. categories = ['images']
  6. base_url = 'https://secure.flickr.com/'
  7. search_url = base_url+'search/?q='
  8. def request(query, params):
  9. global search_url
  10. query = quote(query.replace(' ', '+'), safe='+')
  11. params['url'] = search_url + query
  12. return params
  13. def response(resp):
  14. global base_url
  15. results = []
  16. dom = html.fromstring(resp.text)
  17. for result in dom.xpath('//div[@id="thumbnails"]//a[@class="rapidnofollow photo-click" and @data-track="photo-click"]'):
  18. url = urljoin(base_url, result.attrib.get('href'))
  19. img = result.xpath('.//img')[0]
  20. title = img.attrib.get('alt', '')
  21. img_src = img.attrib.get('data-defer-src')
  22. if not img_src:
  23. continue
  24. results.append({'url': url, 'title': title, 'img_src': img_src, 'template': 'images.html'})
  25. return results