python unzip file

embedded/2025/2/26 12:31:15/

要在 Python 中解压文件并显示进度,我们需要在解压过程中跟踪文件的提取进度。由于 zipfile 模块本身不直接支持进度显示,我们可以通过手动计算并使用 tqdm 库来显示进度条。

安装 tqdm

首先,确保你已经安装了 tqdm 库,用于显示进度条:

 

bash

pip install tqdm

示例代码:解压 .zip 文件并显示进度

 

python

import zipfile
import os
from tqdm import tqdmdef unzip_with_progress(zip_file_path, extract_to_folder):# 打开 zip 文件with zipfile.ZipFile(zip_file_path, 'r') as zip_ref:# 获取压缩包中的所有文件列表all_files = zip_ref.namelist()# 如果目标文件夹不存在,创建它os.makedirs(extract_to_folder, exist_ok=True)# 使用 tqdm 显示进度条,循环解压文件with tqdm(total=len(all_files), desc="解压中", unit="file") as pbar:for file in all_files:# 解压每个文件到目标文件夹zip_ref.extract(file, path=extract_to_folder)# 更新进度条pbar.update(1)print(f"文件已解压到 {extract_to_folder}")# 解压文件并显示进度
zip_file_path = 'your_file.zip'  # 替换成你的 zip 文件路径
extract_to_folder = 'extracted_folder'  # 替换成解压目标文件夹
unzip_with_progress(zip_file_path, extract_to_folder)

python

代码说明:

  1. 获取文件列表:使用 zip_ref.namelist() 获取 .zip 文件中所有文件的名称。这样可以通过 tqdm 显示每个文件的解压进度。
  2. tqdm 进度条tqdm 用于显示进度条,它会根据文件的数量(len(all_files))来显示进度。desc="解压中" 是进度条前的描述信息,unit="file" 表示单位是文件。
  3. 文件解压:通过 zip_ref.extract() 来解压每个文件到指定的目标文件夹。
  4. 进度更新:每解压一个文件,调用 pbar.update(1) 来更新进度条。

示例输出:

当你运行这个脚本时,命令行会显示类似下面的进度条:

解压中: 100%|██████████| 10/10 [00:01<00:00, 9.45file/s]
文件已解压到 extracted_folder

提示:

  • 这个方法对于压缩包中的文件较多时非常有效。
  • 如果文件非常大,进度条更新的速度可能会受到磁盘 I/O 或 CPU 限制的影响。

如果你有更多的要求,或者需要进一步的帮助,随时告诉我!


http://www.ppmy.cn/embedded/167262.html

相关文章

MAC 安装Tensorflow简单方法

MacOS M1 pro安装tensorflow 1、环境配置&#xff08;必需&#xff09; PYTHON版本&#xff1a;3.11.0&#xff0c;python采用homebrew安装。&#xff08;已有python或更高版本可跳过&#xff0c;更高版本未经过测试&#xff0c;题主自认为可行&#xff09; brew install pyt…

将CUBE或3DL LUT转换为PNG图像

概述 在大部分情况下&#xff0c;LUT 文件通常为 CUBE 或 3DL 格式。但是我们在 OpenGL Shader 中使用的LUT&#xff0c;通常是图像格式的 LUT 文件。下面&#xff0c;我将教大家如何将这些文件转换为 PNG 图像格式。 条形LUT在线转换&#xff08;不是8x8网络&#xff09;&am…

DeepSeek 助力 Vue 开发:打造丝滑的滚动动画(Scroll Animations)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…

1.2部署可视化工具es head:9100

ElasticSearch Head是集群管理、数据可视化、增删查改、查询语句可视化工具 1.下载插件 插件下载地址: https://github.com/mobz/elasticsearch-head node下载地址: wget https://registry.npmmirror.com/-/binary/node/latest-v14.x/node-v14.19.3-linux-x64.tar.gz 2.安装插…

【Qt】可爱的窗口关闭确认弹窗实现

文章目录 ​​​实现思路界面构建交互逻辑实现颜色渐变处理圆形部件绘制 代码在主窗口的构造函数中创建弹窗实例ExitConfirmDialog 类代码ColorCircleWidget 类代码 今天在Qt实现了这样一个可互动的窗口&#xff08;上图由于录屏工具限制没有录制到鼠标&#xff09; ​​​实现…

SmartMediakit之音视频直播技术的极致体验与广泛应用

引言 在数字化时代&#xff0c;音视频直播技术已经深入到各个行业和领域&#xff0c;成为信息传递和交流的重要手段。视沃科技自2015年成立以来&#xff0c;一直致力于为传统行业提供极致体验的音视频直播技术解决方案&#xff0c;其旗下的大牛直播SDK凭借强大的功能和卓越的性…

Vue进阶之AI智能助手项目(二)——项目评审与架构设计

AI智能助手项目 基于Vue的最佳实践main.tsApp.vue主应用给子应用下发功能语言language,theme设置及appStore状态管理状态管理router路由index.tspermission.ts基于Vue的最佳实践 src目录概览 api 接口,基于接口可以做 状态处理,interceptorassets/public 静态资源component…

【前端】页面结构管理

在前端开发中&#xff0c;页面结构 的管理有两种常见方式&#xff1a;路由形式 和 组件形式。它们各自有不同的优缺点&#xff0c;适用于不同的场景。以下是它们的对比&#xff1a; 路由形式 在路由形式中&#xff0c;通常会使用前端路由库&#xff08;如 React Router、Vue R…