在写爬虫的时候经常需要根据图片的url直链下载图片到本地,本文整理了根据图片url下载图片的一些方式,大家可以参考参考。
1 python根据url下载图片
1.1 使用urllib下载图片
我们可以使用urllib的urlretrieve函数保存图片,示例代码如下
<code class="language-python line-numbers">from urllib.request import urlretrieve def urllib_download_image(image_url, image_path): urlretrieve(image_url, image_path) if __name__ == '__main__': image_url = 'https://img-blog.csdnimg.cn/20200924162143340.jpg' image_path = './image.jpg' urllib_download_image(image_url, image_path) </code>
1.2 使用request库下载图片
使用request库有两种方式,一种是直接下载,另一种分块保存,一般来说如果图片文件大小在5mb以内就可以直接下载,如果超过5mb则建议使用分块下载的方式,避免内存溢出。
request直接下载
<code class="language-python line-numbers">import requests def request_direct_download_image(image_url, image_path): res = requests.get(image_url) with open(image_path, 'wb') as f: f.write(res.content) if __name__ == '__main__': image_url = 'https://img-blog.csdnimg.cn/20200924162143340.jpg' image_path = './image.jpg' request_direct_download_image(image_url, image_path) </code>
request分块下载
<code class="language-python line-numbers">import requests def request_chunk_download_image(image_url, image_path): res = requests.get(image_url) with open(image_path, 'wb') as f: for chunk in res.iter_content(chunk_size=1024): f.write(chunk) if __name__ == '__main__': image_url = 'https://img-blog.csdnimg.cn/20200924162143340.jpg' image_path = './image.jpg' request_chunk_download_image(image_url, image_path) </code>
这里补充一句,如果我们需要下载的是视频文件,一般来说视频文件都比较大,所以也建议使用分块下载的方式下载视频,代码可参考上面分块下载图片的代码。
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:Python – 根据url下载图片的几种方式整理
原文链接:https://www.stubbornhuang.com/2652/
发布于:2023年06月09日 11:09:51
修改于:2023年06月09日 11:09:51
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论
49