手把手教你用Python實現批量文件的壓縮處理

點擊上方“Python爬蟲與數據挖掘”,進行關注

回覆“書籍”即可獲贈Python從入門到進階共10本電子書

近鄉情更怯,不敢問來人。

一、前言

大家好,我是崔豔飛。接到項目求助,需要對上千個文件夾中的文件進行壓縮處理,並要刪除源文件,只保留壓縮後的壓縮文件,數據量大,手動完成耗時耗力,用Python處理再合適不過了。


二、項目目標

批量對文件夾的內容進行壓縮處理,滿足客戶要求。


三、項目準備

軟件: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!

最後需要本文項目代碼的小夥伴,請在公衆號後臺回覆“文件壓縮”關鍵字進行獲取,如果在運行過程中有遇到任何問題,請隨時留言或者加小編好友,小編看到會幫助大家解決bug噢!

------------------- End -------------------

往期精彩文章推薦:

歡迎大家點贊,留言,轉發,轉載,感謝大家的相伴與支持

想加入Python學習羣請在後臺回覆【入羣

萬水千山總是情,點個【在看】行不行

/今日留言主題/

隨便說一兩句吧~~

本文分享自微信公衆號 - Python爬蟲與數據挖掘(crawler_python)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章