flickr.py 908 B

12345678910111213141516171819202122232425262728
  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. content = '<img src="%s" alt="%s" />' % (img.attrib.get('data-defer-src', ''), title)
  22. results.append({'url': url, 'title': title, 'content': content})
  23. return results