scrapy中使用ImagesPipeline下载图片的方法

scrapy 已经写好了图片下载的方法,只需要调用就可以了.

# scapy 下载图片的源代码
def get_media_requests(self, item, info):
   return [Request(x) for x in item.get(self.images_urls_field, [])]

这个方法很简单,重写此方法,就可以下载需要的图片.需要导入两个模块

from scrapy.pipelines.images import ImagesPipeline
import scrapy


class MyImagePipeline(ImagesPipeline):
    def get_media_requests(self, item, info):
        yield scrapy.Request(url=item['img_url'])

图片会以hashlib.sha1加密的方式命名保存.为了更方便的显示,同样,可以通过重写file_path方法来达到重命名的目的.

# scapy 这是重写后的方法
def file_path(self, request, response=None, info=None):
    img_title = request.meta['item']
    filename = img_title + '.' + request.url.split('.')[-1]
    return filename

但是file_path方法里面没有需要的item数据.所以需要在 get_media_requests方法中把数据传进来.
最后完整的代码如下:

from scrapy.pipelines.images import ImagesPipeline
import scrapy


class MyImagePipeline(ImagesPipeline):
    def get_media_requests(self, item, info):
        print(item['img_url'])
        yield scrapy.Request(url=item['img_url'], meta={'item': item['image_name']})

    def file_path(self, request, response=None, info=None):
        img_title = request.meta['item']
        filename = img_title + '.' + request.url.split('.')[-1]
        return filename

保存图片的时候,只需要在settings里设置图片的路径就可以了(IMAGES_STORE不能变)

IMAGES_STORE = '/home/images'

最后关于路径的问题这里就不详细讨论了,只需要判断一下,不存在建立一个就可以了

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值