网页抓取工具 – 动态start_urls在scrapy

我正在使用scrapy来抓取网站上的多个页面.
变量start_urls用于定义要爬网的页面.
我最初从第一页开始,从而在文件example_spider.py中定义start_urls = [第一页]

从第1页获得更多信息后,我将确定要抓取的下一页是什么,然后相应地分配start_urls.因此,我必须用start_urls = [第1页,第2页,…,第K页]的更改覆盖example_spider.py,然后再次执行scrapy抓取.

这是最好的方法还是有更好的方法来动态地分配start_urls使用scrapy API,而不必覆盖example_splider.py?
谢谢.

解决方法

start_urls类属性包含启动URL – 没有更多.如果您提取了您想要删除的其他页面的URL – 从[另一个]回调的解析回调相应的请求中获得收益:
class Spider(BaseSpider):

    name = 'my_spider'
    start_urls = [
                'http://www.domain.com/'
    ]
    allowed_domains = ['domain.com']

    def parse(self,response):
        '''Parse main page and extract categories links.'''
        hxs = HtmlXPathSelector(response)
        urls = hxs.select("//*[@id='tSubmenuContent']/a[position()>1]/@href").extract()
        for url in urls:
            url = urlparse.urljoin(response.url,url)
            self.log('Found category url: %s' % url)
            yield Request(url,callback = self.parseCategory)

    def parseCategory(self,response):
        '''Parse category page and extract links of the items.'''
        hxs = HtmlXPathSelector(response)
        links = hxs.select("//*[@id='_list']//td[@class='tListDesc']/a/@href").extract()
        for link in links:
            itemLink = urlparse.urljoin(response.url,link)
            self.log('Found item link: %s' % itemLink,log.DEBUG)
            yield Request(itemLink,callback = self.parseItem)

    def parseItem(self,response):
        ...

如果您仍然要自定义开始请求创建,请覆盖方法BaseSpider.start_requests()

相关文章

操作步骤 1、进入elasticsearch的plugin,进入ik。进入config。 2、在config下面建立以.dic为后缀的字典...
lengend data数据中若存在'',则表示换行,用''切割。
代码实现 option = { backgroundColor: '#080b30', tooltip: { trigger: &...
问题原因 原因在于直接在js中取的变量并复制给var变量。 于是就变成这样。 解决办法 var data = &#...
前言 最近做了一个调查问卷导出的功能,需求是将维护的题目,答案,导出成word,参考了几种方案之后,选...
对于很多人来说,用字符编码都是熟能生巧,而不清楚为什么是那样的字符编码,所以我在这列了一个表,翻...