
一、手把手教n实前言
大家好,用P压缩我是现批崔艳飞。接到项目求助,量文需要对上千个文件夹中的处理文件进行压缩处理,并要删除源文件,手把手教n实只保留压缩后的用P压缩压缩文件,数据量大,现批手动完成耗时耗力,量文用Python处理再合适不过了。处理
二、手把手教n实项目目标
批量对文件夹的用P压缩内容进行压缩处理,满足客户要求。现批
三、量文项目准备
软件:PyCharm
需要的处理库:os, shutil,zipfile
四、云服务器提供商项目分析
1)如何读取源文件?
利用OS库,获取文件夹名list,利用for循环,轻松拿到要压缩的源文件。
2)如何进行压缩处理?
利用zipfile库中的zipfile.ZipFile()对获取到的文件进行压缩处理。
3)如何删除源文件?
先利用os库的remove()删除文件,再利用shutil库的rmtree()删除空文件夹。
五、项目实现
1、第一步导入需要的三个库
import os as os import shutil import zipfile 2、第二步定义删除文件函数和压缩文件函数
def del_(rootdir): filelist = [] filelist = os.listdir(rootdir) # 列出该目录下的所有文件名 for f in filelist: filepath = os.path.join(rootdir, f) # 将文件名映射成绝对路劲 if os.path.isfile(filepath): # 判断该文件是否为文件或者文件夹 os.remove(filepath) # 若为文件,则直接删除 elif os.path.isdir(filepath): shutil.rmtree(filepath, True) # 若为文件夹,则删除该文件夹及文件夹内所有文件 shutil.rmtree(rootdir, True) def zipDir(dirpath,outFullName): zip = zipfile.ZipFile(outFullName,"w",zipfile.ZIP_DEFLATED) for path,dirnames,filenames in os.walk(dirpath): # 去掉目标跟路径,亿华云只对目标文件夹下边的文件及文件夹进行压缩 fpath = path.replace(dirpath,) for filename in filenames: zip.write(os.path.join(path,filename),os.path.join(fpath,filename)) zip.close() 3、第三步创建主函数
def main(): path_end = D:/a/h/ date= os.listdir(path_end) # 获取目标文件夹所有文件夹名列表 for f in date: ljbc=D:/a/h/+f+/+查询信息.zip ljbc2 = D:/a/h/ + f + / + 下发修改.zip #以上两行是创建压缩后的文件名 ljcx=D:/a/h/+f+/查询信息 ljxf = D:/a/h/ + f + /下发修改 #以上两行是要压缩的源文件 zipDir(ljcx,ljbc) zipDir(ljxf, ljbc2) del_(ljcx) del_(ljxf) if __name__ == __main__: main() 六、效果展示
1、处理后的文件夹:

2、处理后的文件夹内的压缩文件:

七、总结
本文介绍了如何利用Python对大批量的文件进行批量压缩处理,其实就是几行语句就能实现,程序写好后,不到1分钟就能完成1个人1天也不可能完成的任务。人生苦短,服务器托管要用Python!
