代码效果演示
Gitee源码
# -*- coding: utf-8 -*- # Version: Python 3.9.7 # Author: TRIX # Date: 2021-10-02 13:20:04 # Use: 批量压缩指定文件夹 为zip压缩包 import zipfile from os import path,walk,chdir def zipFiles(pathsList):#需要压缩的文件夹 或 文件列表 for i,r in enumerate(pathsList,1): if path.isfile(r):#如果是文件 fDir,fName=path.split(r) fPre,fSuf=path.splitext(fName) chdir(fDir)#改变当前工作目录 zipPath=fDir+'\\'+fPre+'.zip'#压缩包路径 zipObj = zipfile.ZipFile(zipPath, 'w', zipfile.ZIP_DEFLATED)#以 deflate压缩算法 w模式 创建zip对象 zipObj.write(fName) zipObj.close() else:#如果是文件夹 chdir(r)#改变当前工作目录 fDir,fName=path.split(r) fPre,fSuf=path.splitext(fName) zipPath=fDir+'\\'+fName+'.zip' zipObj = zipfile.ZipFile(zipPath, 'w', zipfile.ZIP_DEFLATED)#以 deflate压缩算法 w模式 创建zip对象 for p, dirs, files in walk(r): for name in files:#拼接文件名 zPath=path.join(p, name).replace(r+'\\','') zipObj.write(zPath) for name in dirs:#拼接目录名 zPath=path.join(p, name).replace(r+'\\','') zipObj.write(zPath) zipObj.close() print('第{}个文件夹压缩完毕,储存路径{}'.format(i,zipPath)) pathsList=[ r'D:\[download]\forTest\folder_for_test\FFT1', r'D:\[download]\forTest\folder_for_test',r'D:\[download]\forTest\folder_for_test\新建 Microsoft Excel 工作表.xlsx'] zipFiles(pathsList)