成功解决将图片字节流转成图片

今天在某搜索网站抓取图片时,最终锁定具体地址之后,通过Request.get请求后得到图片的字节流。

b'RIFF\x90C\x00\x00WEBPVP8 \x84C\x00\x00\x90\xca\x01\x9d\x01*\xf4\x01q\x02>......

通过以下代码成功获得原始大小图片。

    # 使用jsonpath类来解析地址的json数据
    img_urls = jsonpath.jsonpath(response, '$..thumbURL')
    #print(img_urls)
    for img_url in img_urls:
        headers = {
            'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.60 Safari/537.36',
            'content-type': 'image/webp',
            'Accept-Language': 'zh-CN,zh;q=0.9',
            'Accept-Ranges': 'bytes',
            'Accept-Encoding': 'gzip, deflate, br'
        }
        res = requests.get(img_url, headers=headers).content
        # 将bytes结果转化为字节流
        byte_stream = BytesIO(res)
        # 使用图像库Image打开Byte字节流数据
        Img = Image.open(byte_stream)
        # 创建一个空的Bytes对象
        imgByte = io.BytesIO()
        # PNG就是图片格式,我试过换成JPG/jpg都不行
        Img.save(imgByte, format='PNG')
        # 这个就是保存的图片字节流
        imgByte = imgByte.getvalue()
        # 使用UUID给图片命名
        index = uuid.uuid1()
        if not os.path.exists(r'./{}'.format('images')):
            os.mkdir(r'./{}'.format('images'))

        with open(r'./{}/{}.jpg'.format('images', index), 'wb') as f:
            f.write(imgByte)
            print(r'***正在下载: {}.jpg'.format(index))

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值