scrapy入门之meta——不同解析函数之间数据的传递不对应问题

在使用Scrapy爬取新闻网站时,遇到meta参数传递数据导致url和title不对应的问题。原因是meta传递的数据是浅层拷贝,尤其在处理可变数据类型如字典时,可能会因异步请求的特性引发数据错误。解决办法是在接收meta参数时,针对不同url进行判断,确保数据正确性。
摘要由CSDN通过智能技术生成

meta参数传递数据不对应问题

这是个困扰我好几天的大坑,工作中需要爬去新闻网站的新闻数据,总出现item在不同函数之间传递时出现数据不对应的问题,比如url和title对不上之类的,后来知道是由于meta传递的数据是浅层拷贝的原因导致的。

scrapy的meta的作用就是在执行scrapy.Request()函数时把一些回掉函数中需要的数据传进去,meta必须是一个字典,在下一个函数中可以使用response.meta防问,这里需要注意的是,meta传递的数据是浅拷贝传递的,如果传递的数据是可变的数据类型,那么很容易造成数据不对应的错误。

解决办法参考:

def parse(self, response):
    # collect `item_urls`
    for item_url in item_urls:
        yield Request(url=item_url, callback=self.parse_item)
 
 
def parse_item(self, response):
    item = MyItem()
    # populate `item` fields  收集处理一部分数据
    yield Request(url=item_details_url, meta={'item': item},
                  callback=self.parse_details)
 
 
def parse_details(self, response):
    item = response.meta['item']
    # populate more `item` fields  再收集处理另外的数据
    return item
<
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值