news 2026/4/18 8:47:29

Python 实用技:解压 ZIP 文件的三种姿势(从一行命令到进阶脚本)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python 实用技:解压 ZIP 文件的三种姿势(从一行命令到进阶脚本)

Python 实用技:解压 ZIP 文件的三种姿势(从一行命令到进阶脚本)

在日常开发,尤其是 AI 模型部署(如 YOLO、LLM 权重部署)中,我们经常需要在 Linux 服务器或 Docker 容器中处理压缩包。有时候容器里甚至没有安装unzip命令,这时候 Python 就成了我们的救命稻草。

本文总结了使用 Python 解压 ZIP 文件的三种常用方法,涵盖了从最简单的命令行操作到处理中文乱码的进阶技巧。

方法一:命令行“一行流” (最快、无需写脚本)

这是最简单、最快的方法。Python 标准库自带zipfile模块,可以直接在终端调用,无需编写任何.py文件。非常适合在Docker 容器临时环境中使用。

语法:

python -m zipfile -e<压缩包名><解压目标目录>

示例:
model_weights.zip解压到当前目录(.):

python -m zipfile -e model_weights.zip.

原理-m参数将库模块当作脚本运行,-e代表 extract(解压)。


方法二:标准库zipfile(基础脚本)

如果你需要在 Python 代码中集成解压功能,zipfile是最标准的选择。建议使用with语句(上下文管理器),这样可以确保文件在使用后自动关闭,即使发生错误也不会占用文件句柄。

importzipfileimportosdefunzip_file(zip_src,dst_dir):# 如果目标目录不存在,则创建ifnotos.path.exists(dst_dir):os.makedirs(dst_dir)print(f"开始解压:{zip_src}...")try:withzipfile.ZipFile(zip_src,'r')aszfile:# extractall 会解压所有文件zfile.extractall(path=dst_dir)print(f"✅ 解压完成,文件已保存至:{dst_dir}")exceptzipfile.BadZipFile:print("❌ 错误: 文件已损坏或不是有效的 ZIP 文件")exceptExceptionase:print(f"❌ 发生未知错误:{e}")# 调用示例if__name__=="__main__":unzip_file("merged_qwen3vl_model.zip","./model_output")

方法三:进阶操作 (大文件进度条 + 中文乱码修复)

作为 AI 开发者,我们解压的模型往往高达几 GB 甚至几十 GB。如果没有进度条,对着黑屏傻等是非常焦虑的。此外,Windows 下打包的中文文件名在 Linux 下解压常会出现乱码。

下面的脚本解决了这两个痛点:

1. 依赖安装

我们需要tqdm来显示进度条(做 AI 的同学应该都有这个库):

pipinstalltqdm

2. 完整代码

importzipfileimportosfromtqdmimporttqdmdefunzip_with_progress(zip_src,dst_dir):ifnotos.path.exists(dst_dir):os.makedirs(dst_dir)withzipfile.ZipFile(zip_src,'r')aszfile:# 获取所有文件列表members=zfile.infolist()# 初始化进度条,total 是文件总大小total_size=sum(file.file_sizeforfileinmembers)print(f"正在解压{zip_src}{dst_dir}...")withtqdm(total=total_size,unit='B',unit_scale=True,unit_divisor=1024)aspbar:formemberinmembers:# --- 中文乱码修复核心代码 (可选) ---# Windows 压缩包通常用 CP437 编码文件名,Linux 需要转回 GBK 或 UTF-8try:member.filename=member.filename.encode('cp437').decode('gbk')except:# 如果转换失败,保持原样(说明可能是 UTF-8)pass# --------------------------------# 解压单个文件zfile.extract(member,dst_dir)# 更新进度条pbar.update(member.file_size)if__name__=="__main__":# 示例:解压一个大模型权重unzip_with_progress("large_model_weights.zip","./models")

总结

场景推荐方法核心命令/库
临时操作/Docker环境方法一python -m zipfile -e file.zip .
通用脚本开发方法二import zipfile
大文件/体验优化方法三zipfile+tqdm

希望这篇笔记能帮你解决 Linux 环境下的解压难题!如果觉得有用,欢迎点赞收藏。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 14:57:57

还在手动合并Word?5分钟掌握Python自动化解决方案

第一章&#xff1a;还在手动合并Word&#xff1f;5分钟掌握Python自动化解决方案在日常办公中&#xff0c;频繁处理多个 Word 文档的合并任务不仅耗时&#xff0c;还容易出错。借助 Python 强大的文档处理库 python-docx 和 glob&#xff0c;我们可以轻松实现文档的批量合并&am…

作者头像 李华
网站建设 2026/4/18 3:28:28

20260121人工智能作业v2

文章目录一、核心命令清单&#xff08;逐条执行&#xff0c;需root权限&#xff09;1. 校验并创建用户组 dev_team2. 创建用户 alice&#xff08;指定主组安全配置&#xff09;3. 创建用户 bob&#xff08;同alice&#xff0c;仅用户名不同&#xff09;4. 创建 /opt/project 目…

作者头像 李华
网站建设 2026/4/18 5:23:30

【Python字典排序终极指南】:按value大小排序的5种高效方法揭秘

第一章&#xff1a;Python字典排序的核心概念与应用场景Python 字典&#xff08;dict&#xff09;是一种无序的键值对集合&#xff0c;但在实际开发中&#xff0c;经常需要根据键、值或特定规则对字典进行排序。自 Python 3.7 起&#xff0c;字典保持插入顺序成为语言规范&…

作者头像 李华
网站建设 2026/4/18 6:31:35

【收藏】一文读懂大模型:从小白到高薪AI开发者的进阶之路

文章介绍了大模型的基本概念、特点&#xff08;训练数据、架构、参数、算力四大方面&#xff09;及行业应用。指出大模型是第四次工业革命&#xff0c;人才需求旺盛&#xff0c;就业前景广阔。推荐了尚硅谷AI大模型课程&#xff0c;包含10个实战项目和10个学习阶段&#xff0c;…

作者头像 李华
网站建设 2026/4/18 5:24:21

【Python字符串转datetime终极指南】:掌握8种常见格式转换技巧

第一章&#xff1a;Python字符串转datetime基础概念在Python中处理时间数据时&#xff0c;经常需要将表示日期和时间的字符串转换为datetime对象&#xff0c;以便进行算术运算、格式化输出或时区转换等操作。这一过程依赖于标准库datetime中的strptime()方法&#xff0c;它能根…

作者头像 李华
网站建设 2026/4/18 8:40:56

Python自动合并Word文档实战(职场效率提升90%)

第一章&#xff1a;Python自动合并Word文档实战&#xff08;职场效率提升90%&#xff09; 在日常办公中&#xff0c;频繁处理多个Word文档的合并任务不仅耗时&#xff0c;还容易出错。利用Python结合python-docx库&#xff0c;可以轻松实现文档的自动化合并&#xff0c;大幅提升…

作者头像 李华