Python实现批量文件的压缩处理
推荐
在线提问>>
一、前言
接到项目求助,需要对上千个文件夹中的文件进行压缩处理,并要删除源文件,只保留压缩后的压缩文件,数据量大,手动完成耗时耗力,用Python处理再合适不过了。
二、项目目标
批量对文件夹的内容进行压缩处理,满足客户要求。
三、项目准备
软件:PyCharm
需要的库:os,shutil,zipfile
四、项目分析
1)如何读取源文件?
利用OS库,获取文件夹名list,利用for循环,轻松拿到要压缩的源文件。
2)如何进行压缩处理?
利用zipfile库中的zipfile.ZipFile()对获取到的文件进行压缩处理。
3)如何删除源文件?
先利用os库的remove()删除文件,再利用shutil库的rmtree()删除空文件夹。
五、项目实现
1、第一步导入需要的三个库
importosasos
importshutil
importzipfile
2、第二步定义删除文件函数和压缩文件函数
defdel_(rootdir):
filelist=[]
filelist=os.listdir(rootdir)#列出该目录下的所有文件名
forfinfilelist:
filepath=os.path.join(rootdir,f)#将文件名映射成绝对路劲
ifos.path.isfile(filepath):#判断该文件是否为文件或者文件夹
os.remove(filepath)#若为文件,则直接删除
elifos.path.isdir(filepath):
shutil.rmtree(filepath,True)#若为文件夹,则删除该文件夹及文件夹内所有文件
shutil.rmtree(rootdir,True)
defzipDir(dirpath,outFullName):
zip=zipfile.ZipFile(outFullName,"w",zipfile.ZIP_DEFLATED)
forpath,dirnames,filenamesinos.walk(dirpath):
#去掉目标跟路径,只对目标文件夹下边的文件及文件夹进行压缩
fpath=path.replace(dirpath,'')
forfilenameinfilenames:
zip.write(os.path.join(path,filename),os.path.join(fpath,filename))
zip.close()
3、第三步创建主函数
defmain():
path_end='D:/a/h/'
date=os.listdir(path_end)
#获取目标文件夹所有文件夹名列表
forfindate:
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()
以上内容为大家介绍了Python实现批量文件的压缩处理,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。http://www.mobiletrain.org/