Scrapy Может ли фильтр дубликатов быть постоянным с заданиями?

from scrapy.exceptions import DropItem

class DuplicatesPipeline(object):

    def __init__(self):
        self.ids_seen = set()

    def process_item(self, item, spider):
        if item['id'] in self.ids_seen:
            raise DropItem("Duplicate item found: %s" % item)
        else:
            self.ids_seen.add(item['id'])
            return item

Приведенный выше код взят с официального сайта Scrapy: http://doc.scrapy.org/en/latest/topics/item-pipeline.html, который используется для фильтрации дубликатов.

И, как было предложено в документации Scrapy, http://doc.scrapy.org/en/latest/topics/jobs.html Чтобы приостановить и возобновить работу паука, мне нужно использовать систему Jobs.

Так что мне любопытно, может ли система Scrapy Jobs сделать фильтр дубликатов постоянным в своем каталоге. Способ реализации фильтра дубликатов настолько прост, что я сомневаюсь.


person Jaesung    schedule 05.11.2019    source источник


Ответы (1)


Вам просто нужно реализовать свой конвейер так, чтобы он считывал параметр JOBDIR и, когда этот параметр определен, ваш конвейер:

  1. Читает начальное значение self.ids_seen из некоторого файла в каталоге JOBDIR.

  2. Во время выполнения он обновляет этот файл по мере добавления новых идентификаторов в набор.

person Gallaecio    schedule 06.11.2019