说明:对文件夹的压缩,文件的解压处理原理存在差异,因此处理难度也不一样,压缩的难度更高一点,主要是压缩的时候,文件夹下可能存在文件夹、文件,需要获取到所有被嵌套的文件绝对路径(难点)
代码实现
import os
import zipfile
path_src = './video_no_ed/chx/'
path_save = './video_ed/chx/'
def _jieya(path_src, path_save):
'''
:param path_src: 需要解压的文件路径(注意后面需要保留反斜杠, 下同)
:param path_save: 保存到指定的文件夹路径
:return: None
'''
# 获取当前文件夹下的所有压缩文件
files = os.listdir(path_src)
# 遍历压缩文件进行解压,并将解压后的文件or文件夹保存到指定位置
for i in range(len(files)):
fz = zipfile.ZipFile(path_src + files[i], 'r')
for file in fz.namelist():
fz.extract(file, path_save)
return None
def _jieya(path_src, path_save)
代码实现
import os
import zipfile
#需要被压缩的文件夹路径
yuan_path = './video_ed/chx/'
#压缩后需要保存指定的文件夹路径
mu_path = './video_no_ed/chx/'
#获取原文件夹下的所有文件夹或者文件
yuan_sub_path = os.listdir(yuan_path)
def _yasuo(yuan_path, mu_path):
for i in range(len(yuan_sub_path)):
# 创建一个类对象,传入 压缩后需要保存的路径+压缩文件名
f = zipfile.ZipFile(os.path.abspath(mu_path + yuan_sub_path[i] + '.zip'), 'w', zipfile.ZIP_DEFLATED)
# 建一个空列表,用于存储需要进行压缩的文件夹以及文件的绝对路径
ziplist = []
# 递归遍历需要被压缩的文件夹(如下图32013704)下的所文件夹或文件,获取文件路径 -- 难点
for dir, subdirs, files in os.walk(yuan_path + yuan_sub_path[i]):
for fileitem in files:
ziplist.append(os.path.join(dir, fileitem))
for diritem in subdirs:
ziplist.append(os.path.join(dir, diritem))
print(ziplist)
# 将文件进行压缩写入
for j in ziplist:
f.write(j, j.replace(yuan_path, ''))
f.close()
_yasuo(yuan_path, mu_path)