当前位置:Gxlcms > Python > Python自定义scrapy中间模块避免重复采集的方法

Python自定义scrapy中间模块避免重复采集的方法

时间:2021-07-01 10:21:17 帮助过:20人阅读

本文实例讲述了Python自定义scrapy中间模块避免重复采集的方法。分享给大家供大家参考。具体如下:

  1. from scrapy import log
  2. from scrapy.http import Request
  3. from scrapy.item import BaseItem
  4. from scrapy.utils.request import request_fingerprint
  5. from myproject.items import MyItem
  6. class IgnoreVisitedItems(object):
  7. """Middleware to ignore re-visiting item pages if they
  8. were already visited before.
  9. The requests to be filtered by have a meta['filter_visited']
  10. flag enabled and optionally define an id to use
  11. for identifying them, which defaults the request fingerprint,
  12. although you'd want to use the item id,
  13. if you already have it beforehand to make it more robust.
  14. """
  15. FILTER_VISITED = 'filter_visited'
  16. VISITED_ID = 'visited_id'
  17. CONTEXT_KEY = 'visited_ids'
  18. def process_spider_output(self, response, result, spider):
  19. context = getattr(spider, 'context', {})
  20. visited_ids = context.setdefault(self.CONTEXT_KEY, {})
  21. ret = []
  22. for x in result:
  23. visited = False
  24. if isinstance(x, Request):
  25. if self.FILTER_VISITED in x.meta:
  26. visit_id = self._visited_id(x)
  27. if visit_id in visited_ids:
  28. log.msg("Ignoring already visited: %s" % x.url,
  29. level=log.INFO, spider=spider)
  30. visited = True
  31. elif isinstance(x, BaseItem):
  32. visit_id = self._visited_id(response.request)
  33. if visit_id:
  34. visited_ids[visit_id] = True
  35. x['visit_id'] = visit_id
  36. x['visit_status'] = 'new'
  37. if visited:
  38. ret.append(MyItem(visit_id=visit_id, visit_status='old'))
  39. else:
  40. ret.append(x)
  41. return ret
  42. def _visited_id(self, request):
  43. return request.meta.get(self.VISITED_ID) or request_fingerprint(request)

希望本文所述对大家的Python程序设计有所帮助。

人气教程排行