Dynamically add to allowed_domains in a Scrapy spider

后端 未结 2 1529
走了就别回头了
走了就别回头了 2021-01-20 12:35

I have a spider that starts with a small list of allowed_domains at the beginning of the spidering. I need to add more domains dynamically to this whitelist as

2条回答
  •  悲&欢浪女
    2021-01-20 13:05

    (At the very moment when this answer is written, the latest version of scrapy is 1.0.3. This answer shall work for all recent versions of scrapy)

    As the OffsiteMiddleware reads the content in allowed_domains only when initializing the precompiled regex object while handling the spider_opened signal, values in allowed_domains are never accessed later.
    Thus simply updating the content of allowed_domains shall not solve the problem.

    Basically, two steps are required:

    1. Update the content of allowed_domains according to your actual need.
    2. Have the regex cache in OffsiteMiddleware refreshed.

    Here is the code I use for step #2:

    # Refresh the regex cache for `allowed_domains`
    for mw in self.crawler.engine.scraper.spidermw.middlewares:
        if isinstance(mw, scrapy.spidermiddlewares.offsite.OffsiteMiddleware):
            mw.spider_opened(self)
    

    The code above is supposed to be invoked inside a response callback, thus self here shall be an instance of the spider class.

    See also:

    • Source code of scrapy.spidermiddlewares.offsite.OffsiteMiddleware on GitHub

提交回复
热议问题