Scrapy命令行动态传参给spider

scrapy命令行执行传递多个参数给spider 动态传参

在命令行运行scrapy爬虫

scrapy crawl spider_name

若爬虫中有参数可以控制爬取的页数,那么想要在输入命令行命令时传递页数给爬虫,就可以这样做

在spider中定义一个构造函数

    def __init__(self, pages=None, *args, **kwargs):
        super(LvideoSpider, self).__init__(*args, **kwargs)
        # super().__init__(**kwargs)
        self.pages = pages
        
    ...
    def parse(self, response):
        pages = re.findall(r'当前:1/(\d+)页', response.text, re.S)[0]
        link = response.meta['format_page']
        # 如果self.pages存在,那么就会代替正则取到的页数
        if self.pages:
            pages = self.pages
            print('共' + str(pages) + '页')
        for page in range(1, int(pages) + 1):
            page_link = link.format(page)
            yield Request(page_link, callback=self.parse_video_link,
                          meta={'soucre_name': response.meta['soucre_name'],
                                'domin': response.meta['domin'],
                                'page_link': page_link}, dont_filter=True)

然后在启动scrapy的时候就可以赋予参数的值:

scrapy crawl spider_name -a pages=10

这样就控制了爬取页数为10页

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值