【python实用小脚本-139】Python 在线图片批量下载器:requests+PIL 一键保存网络图像

引言

设计师小李每天都要从 Unsplash、Pinterest 等站点收集灵感图。手动"右键-另存为"不仅慢,而且容易重名、格式混乱。他想要一个能自动识别图片格式、按顺序编号保存的小工具。于是,这个 30 行不到的 main.py 成为他的"效率神器":只需把图片 URL 复制进去,回车即可自动保存到脚本所在目录,再也不用手动整理。

代码解析说明(附源码)

python 复制代码
import requests
from PIL import Image
from io import BytesIO
import os

download_path = os.path.dirname(os.path.abspath(__file__))  # 当前脚本所在目录
count = 1                                                  # 自动编号起始值
while True:                                                # 持续交互
    url = input("Enter Image URL: ")
    try:
        res = requests.get(url, timeout=10)
        res.raise_for_status()                            # 检查 404/500
    except Exception as e:
        print("Invalid URL / Can't Access The URL", e)
        continue

    img = Image.open(BytesIO(res.content))                # 内存解码图片
    fmt = img.format or 'JPEG'                            # 兜底格式
    file_name = f"{count}.{fmt.lower()}"
    save_path = os.path.join(download_path, file_name)
    img.save(save_path, format=fmt.upper())               # 按原始格式保存
    print(f"Image Downloaded: {save_path}")
    count += 1                                            # 递增编号

要点解析

  • requests:下载二进制流,支持 HTTPS、重定向、超时控制。
  • PIL.Image:自动识别图片真实格式(PNG/JPEG/WebP 等)。
  • os.path.abspath(file):跨平台获取脚本目录,无需手动配置路径。
  • 异常捕获:网络异常或格式错误不会导致程序崩溃,体验友好。

可扩展的两个场景

a. 批量壁纸爬虫

while True 改为读取文本文件 URL 列表,即可一次性爬取并编号保存 1000 张壁纸。

b. 电商 SKU 图片同步

结合正则解析商品详情页中的所有 <img> 标签,自动下载并命名为商品 ID,提高商品上新效率。

总结

这段不到 30 行的 Python 脚本结合了 requests 的高速下载和 PIL 的格式识别能力,实现了"极简、零配置"的在线图片下载器。无论是设计师、运营还是爬虫开发者,都能在此基础上快速扩展,满足壁纸收集、商品图同步、训练数据抓取等多场景需求,真正做到"复制-回车-完成"。

源码获取

完整代码已开源,包含详细的注释文档:

🔗 [GitCode仓库] https://gitcode.com/laonong-1024/python-automation-scripts

📥 [备用下载] https://pan.quark.cn/s/654cf649e5a6 提取码:f5VG

相关推荐
fen_fen1 小时前
用户信息表建表及批量插入 100 条数据(MySQL/Oracle)
数据库·mysql·oracle
马克Markorg8 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
冷雨夜中漫步8 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再8 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
绵绵细雨中的乡音8 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
喵手10 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
Coder_Boy_10 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
2501_9449347310 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy10 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python