【Python_文件批量解压&压缩】

Python_文件批量解压&压缩

说明:对文件夹的压缩,文件的解压处理原理存在差异,因此处理难度也不一样,压缩的难度更高一点,主要是压缩的时候,文件夹下可能存在文件夹、文件,需要获取到所有被嵌套的文件绝对路径(难点)

压缩文件批量解压

功能效果图:

解压前:
【Python_文件批量解压&压缩】_第1张图片
解压后
【Python_文件批量解压&压缩】_第2张图片

代码实现

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)

单个文件夹压缩示意图

需被压缩的文件夹
【Python_文件批量解压&压缩】_第3张图片

压缩后的文件(保留文件夹下的所有文件夹和文件)
【Python_文件批量解压&压缩】_第4张图片

你可能感兴趣的:(python)