温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Python如何批量对文件进行压缩处理

发布时间:2022-05-25 11:15:25 来源:亿速云 阅读:232 作者:zzz 栏目:大数据

这篇文章主要介绍“Python如何批量对文件进行压缩处理”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python如何批量对文件进行压缩处理”文章能帮助大家解决问题。

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、处理后的文件夹:

 Python如何批量对文件进行压缩处理

关于“Python如何批量对文件进行压缩处理”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI