15《Python 办公自动化教程》文件压缩与解压缩
off999 2025-07-27 23:18 3 浏览 0 评论
压缩包也是我们平时工作中经常要接触到的文件格式,压缩文件后缀名通常有 .zip、.rar、.7z 等等。Python 中也有专门用来操作压缩包文件的第三方模块 zipfile。听这个名字就知道是用来操作压缩包文件的了,这个第三方模块也是我们本节课的重点,下面我们就一起来看一下。
1. zipfile 模块介绍
zip 文件格式是通用的文档压缩标准,在 ziplib 模块中,提供 ZipFile 类操作 zip 文件,如创建、读取、写入、附加、显示压缩文件等操作。
1.1 安装
zipfile 是 Python 的第三方库,使用前需要通过以下命令进行安装:
pip install zipfile
1.2 使用步骤
步骤 1:导入 zipfile 模块
import zipfile
步骤 2:实例化 zipfile 对象
z = zipfile.ZipFile(file, mode='r')
打开或者新建一个 zip 文件对象,第一个参数为 file 文件地址,第二个参数为打开模式,当模式参数是 ‘r’ 表示读取现有的文件,为 ‘w’ 表示覆盖或写入一个新的文件,为 ‘a’ 表示将追加到现有文件。
步骤 3:进行压缩文件操作
通过 zipfile 模块提供的方法对压缩文件进行创建、读取、解压等操作。
步骤 4:关闭压缩文件
z = zipfile.ZipFile(file, mode='r')
...省略部分代码
z.close()
注意:zipfile 在使用后,必须在退出程序之前调用 close () 方法否则将不会写入关键记录数据。
2. 使用 zipfile 模块进行压缩与解压缩
现在 D:\code 目录已有 code.zip,内容如下图所示。
接下来通过 zipfile 模块对压缩文件进行操作,zipfile 模块操作压缩文件常用方法见下表。
方法名 | 描述 |
namelist() | 返回 ZIP 文件内所有成员名字列表 |
write() | 添加文件到压缩包内 |
extract(member[, path[, pwd]]) | 解压单个文件,参数 members 表示 zipfile 对象中某个文件名,path 为解压到的目的路径,默认是压缩包所在路径,pwd 为压缩包密码,默认无密码 |
extractall([path[, members[, pwd]]]) | 解压所有文件,参数 path 为解压到的目的路径,默认是压缩包所在路径,members 默认值是压缩包文件中所有文件名称列表,也可以另外指定,pwd 为压缩包密码,默认无密码 |
下面来具体看下每个方法的使用:
- namelist () 使用:
import zipfile, os
zipFile = zipfile.ZipFile(os.path.join(os.getcwd(), 'code.zip'))
print(zipFile.namelist())
#输出: ['code/', 'code/index.py', 'code/newimage/', 'code/writeppt.py', 'code/writeword.py']
代码解释:namelist () 方法获取压缩包中所有文件的名字,并组成列表返回。首先通过 ZipFile 实例化 zip 文件对象,其中压缩文件这里通过 OS 模块的 join 方法进行拼接,返回一个绝对路径。通过 namelist () 方法打印输出:
['code/', 'code/index.py', 'code/newimage/', 'code/writeppt.py', 'code/writeword.py']
- write () 使用:
import zipfile, os
zipFile = zipfile.ZipFile(os.path.join(os.getcwd(), 'code.zip'),'a')
zipFile.write("test.txt")
print(zipFile.namelist())
#输出: ['code/', 'code/index.py', 'code/newimage/', 'code/writeppt.py', 'code/writeword.py','code/test.txt']
代码解释:write () 方法为添加文件到压缩文件,在 D:\code 目录下,创建 test.txt 文件,通过 wirte () 方法添加到现有压缩文件 code.zip 中,执行完成后,通过 namelist () 方法重写打印压缩文件中所有成员名字列表,输出 ['code/', 'code/index.py', 'code/newimage/', 'code/writeppt.py', 'code/writeword.py','code/test.txt']。上述代码中需要注意:
向压缩文件中写入内容时,注意修改 zipFile 实例化处的模式,默认为 “r”,表示只读,不可以写入,设置为 “w” 后可以写入,但会覆盖原有压缩文件中内容,如果想要追加,设置为 “a” 即可。
- extract () 使用:
import zipfile, os
zipFile = zipfile.ZipFile(os.path.join(os.getcwd(), 'code.zip'))
for file in zipFile.namelist():
zipFile.extract(file)
zipFile.close()
代码解释:extract () 方法为单个压缩文件解压,代码中结合 namelist () 方法将 D:\code\code.zip 进行解压缩操作,解压后效果如下图所示。
- extractall () 使用:
import zipfile, os
zipFile = zipfile.ZipFile(os.path.join(os.getcwd(), 'code.zip'))
zipFile.extractall()
zipFile.close()
代码解释:extractall () 方法为解压 zip 文档中的所有文件到指定目录,默认为压缩包所在路径,即当前目录。代码执行完成后,效果同 extract () 结合 namelist () 方法进行解压操作一样。
3. zipfile 模块实战
在上一小节中,使用 os 模块封装了程序遇到异常情况时记录错误日志文件的方法,本小节 zipfile 模块实战在上一小节代码的基础上进行实现。
在服务器上存储的错误日志文件,一定周期需要进行下载,为了防止下载过程中出现文件丢失或乱码的情况,通常采用创建压缩包的形式。但手动创建无疑是费时费力且容易出现错误的,这时可以使用 zipfile 模块结合 os 模块,实现将 2020 年下,每个月份的错误日志记录文件夹,创建相对的压缩文件,如 1 月,对应 1.zip,2 月对应 2.zip。目前服务器上 1-11 月的错误日志文件存储结构如下图所示。
以 1 月为例,1 月文件夹下的文件存储结构如下图所示。
根据上述需求背景,封装后的代码如下:
import zipfile
import os
# 制定要生成压缩文件的路径
filepath = "./2020"
# 创建压缩文件
def createzipfile(month):
# 压缩包文件名称
zipName = month + '.zip'
f = zipfile.ZipFile(zipName, 'a')
# 遍历当前文件夹
for dirpath, dirnames, filenames in os.walk(filepath+"/"+month):
for filename in filenames:
f.write(os.path.join(dirpath, filename))
f.close()
# 遍历当前目录下的文件夹
for item in os.listdir(filepath):
# 调用创建压缩文件方法
createzipfile(str(item))
代码解释:通过 os.listdir () 方法获取到要压缩的目录下所有的文件夹,即获取到 1,2,3,4…,在遍历中调用 createzipfile () 方法,将文件夹名称传入。在 createzipfile () 方法中,使用 zipfile.ZipFile 创建压缩文件,在向压缩文件写入内容时,通过 os.walk () 方法对当前月的目录进行遍历,嵌套 for…in 循环中,将文件写入到压缩文件。代码执行完成后,创建好的压缩文件如下图所示。
4. 小结
本节课程我们主要学习了 zipfile 模块的使用。本节课程的重点如下:
- 了解 zipfile 模块作用及使用步骤;
- 掌握 zipfile 模块中压缩与解压缩操作的使用方法;
- 上一篇:08《Python 办公自动化教程》smtplib 模块与 email 模块
- 已经是最后一篇了
相关推荐
- 16《Python 办公自动化教程》钉钉群机器人配置
-
在互联网企业中,数字化办公早已经不是什么新鲜事了,其中以钉钉为代表的工具更是其中的主力军。目前公司中钉钉的使用已经较为普及,像钉钉打卡、钉钉会议室、钉盘等。本小节将针对钉钉群机器人进行介绍,助力利用钉...
- 15《Python 办公自动化教程》文件压缩与解压缩
-
压缩包也是我们平时工作中经常要接触到的文件格式,压缩文件后缀名通常有.zip、.rar、.7z等等。Python中也有专门用来操作压缩包文件的第三方模块zipfile。听这个名字就知道是用来操...
- 08《Python 办公自动化教程》smtplib 模块与 email 模块
-
日常办公中正式文件的发送都需要用到邮件,以及在互联网工作中,月度总结、销售报表、考评表等等都需要邮件进行发送。在不考虑办公自动化之前,你发送一封邮件的步骤是如何呢?第一步打开浏览器进入到邮箱登录界面,...
- 好用的五个python表格自动化工具,谁都可以复制直接用
-
引言在之前文章中,有一篇《这五个办公室常用自动化工具我用python帮你写好了,复制代码就能用》,没想到受到了广大读者的喜爱。其中进行了一个投票,总结发现很多读者对于excel的自动化需求非常高,...
- 1-Pytest全栈自动化测试指南- 运行
-
通常,使用命令调用pytest(有关调用pytest的其他方法,pytest请参见下文)。这将在名称遵循表单的所有文件中或在当前目录及其子目录中执行所有测试。更一般地说,pytest遵...
- Python40个自动化办公实战案例,终于实现下班自由啦~
-
拿来就能用,这么爽的吗?!今天我想聊聊,如何通过Python自动化工具,解决工作中常见的办公效率低下的问题。你有没有想过,下班晚,加班,可能是因为自己工作比较低效?回想一下,自己是不是也曾遇到过这样的...
- Python自动化 | 解锁高效办公利器,Python助您轻松驾驭Excel!
-
大家不论在日常工作还是生活中,都经常用到Excel这款办公软件,它在数据处理、报表生成等方面起到了重要作用。然而,作为一个Python工程师,你可知道Python也能成为操作Excel的得力助手吗?而...
- Python自动化办公实战:包含Word、Excel、Pdf和Email邮件案例
-
背景想象一下,现在你有一份Word邀请函模板,然后你有一份客户列表,上面有客户的姓名、联系方式、邮箱等基本信息,然后你的老板现在需要替换邀请函模板中的姓名,然后将Word邀请函模板生成Pdf格式,之后...
- Python自动化办公学习笔记11——布尔类型、变量赋值、类型转换
-
1.布尔类型(Boolean)在Python中,布尔类型是整数类型的子类,其中`True`表示"真"或"是",`False`表示"假"或"否&...
- Python自动化办公应用学习笔记9——赋值语句、i...
-
1.赋值语句在程序中产生或计算值的代码称为表达式。Python语言中,等号(=)表示“赋值”操作,即将右侧表达式的计算结果赋给左侧的变量。包含等号(=)的语句称为赋值语句。同步赋值语句可以...
- Python自动化办公应用学习笔记13——表达式
-
1.表达式基础定义:表达式是代码中能计算并返回一个值的代码片段。组成:由操作数(变量、字面量)和操作符(运算符、函数调用)构成。特点:不包含语句(如if、for)、可嵌套(如(a+b)*...
- Python办公自动化之操作Excel(一)
-
处理Excel的库主要有xlrd、xlwt、xlwings和openpyxl。xlrd、xlwt、xlwings可以用于处理Excel2010文档之前的文档,而openpyxl是用于处理Excel...
- Python办公自动化系列篇之五:Web 自动化与数据提取
-
作为高效办公自动化领域的主流编程语言,Python凭借其优雅的语法结构、完善的技术生态及成熟的第三方工具库集合,已成为企业数字化转型过程中提升运营效率的理想选择。该语言在结构化数据处理、自动化文档生成...
- Python自动化办公应用学习笔记18—— while循环
-
1.定义while循环(条件循环/无限循环)是Python中基于条件判断的循环结构。它不需要预先知道循环次数,只要条件满足就会持续执行代码块,直到条件变为False时停止。特别适合处理动态变...
- Python自动化办公应用学习笔记15——算法
-
针对各种类型的问题,拟定出有效的解决方法和步骤,也就是算法。可以说,设计算法是程序设计的核心。简单来说,为解决一个问题而采取的具体方法和操作步骤,就称为“算法”。比如在解决一个数值计算问题时,我们不仅...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 16《Python 办公自动化教程》钉钉群机器人配置
- 15《Python 办公自动化教程》文件压缩与解压缩
- 08《Python 办公自动化教程》smtplib 模块与 email 模块
- 好用的五个python表格自动化工具,谁都可以复制直接用
- 1-Pytest全栈自动化测试指南- 运行
- Python40个自动化办公实战案例,终于实现下班自由啦~
- Python自动化 | 解锁高效办公利器,Python助您轻松驾驭Excel!
- Python自动化办公实战:包含Word、Excel、Pdf和Email邮件案例
- Python自动化办公学习笔记11——布尔类型、变量赋值、类型转换
- Python自动化办公应用学习笔记9——赋值语句、i...
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)