python如何获取网络上的图片并将其保存在本地

编程知识 更新时间:2023-04-06 19:02:45

之前写爬虫大多是爬网页中的url,然后将url保存下来就可以了,倒还没有想过要获取真的图片到本地。

网络上有很多方法,但是很多都是本地,或者其他:

方法一:使用urllib.urlretrieve()

之前其实偶尔看到这个函数,但一直记不住它是做什么的,主要是没在实战中用上,这是最简单的方法:

import urllib

# 网络上图片的地址
img_src = 'https://img-my.csdn/uploads/201212/25/1356422284_1112.jpg'

# 将远程数据下载到本地,第二个参数就是要保存到本地的文件名
urllib.urlretrieve(img_src,'D:/1.jpg')

关于urllib.urlretrieve()的解释,来源:http://www.nowamagic/academy/detail/1302861

方法二:通过requests:

使用open

将图片流通过以二进制写模式打开文件并写入

import requests

img_src = 'https://xxx.jpg'
response = requests.get(img_src)
with open('D:/tmp.jpg','wb') as file_obj:
    file_obj.write(response.content)
使用PIL:

当项目里使用到PIL的时候,需要结合io.BytesIO()将图片流写入文件。它是用来操作二进制数据的,图片就是二进制数据了,和它相对的自然是StringIO,这是用来存str的。他们的区别就好似python读写普通文件和二进制文件。

import requests
from PIL import Image
from io import BytesIO

img_src = 'https://xxx.jpg'
response = requests.get(img_src)
image = Image.open(BytesIO(response.content))
image.save('D:/9.jpg')

更多推荐

python如何获取网络上的图片并将其保存在本地

本文发布于:2023-04-06 19:02:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/73c8a6e6bf39565cd688c77c19b36a65.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:图片   并将其   网络   python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!

  • 50447文章数
  • 14阅读数
  • 0评论数