詳解Python 解壓縮文件
zipfile模塊及相關方法介紹:
1 壓縮
1.1 創(chuàng)建zipfile對象
zipfile.ZipFile(file, mode='r', compression=0, allowZip64=True, compresslevel=None)
創(chuàng)建Zipfile對象,主要參數(shù):
1>file壓縮包名稱;
2>mode:讀'r'或者寫'w'模式;
3>compression:設置壓縮格式;
4>compresslevel:壓縮等級;
壓縮格式分類:
1.2 添加壓縮文件
zipobj.write(self, filename, arcname=None, compress_type=None, compresslevel=None)
參數(shù)說明:
1>fiename:添加文件路徑;
2>arcname:歸檔文件路徑與名稱;
1.3 添加壓縮數(shù)據(jù)
zipobj.writestr(zinfo_or_arcname, data, compress_type=None, compresslevel=None)
參數(shù)說明:
1>zinfo_or_arcname:歸檔文件名稱;
2>data:壓縮數(shù)據(jù)str或者byte,如果數(shù)據(jù)為str,需要先進行Utf-8編碼;
1.4 關閉
關閉壓縮文件:
zipobj.close()
1.5 一個例子:
壓縮目錄如下:
代碼實現(xiàn):
import zipfile logdir = '/home/linux/logs' zipname = '/home/linux/logs.zip' #創(chuàng)建zip對象, fzip = zipfile.ZipFile(zipname, 'w', zipfile.ZIP_DEFLATED) #遍歷要壓縮目錄 flist = os.listdir(logdir) for name in flist: fpath = os.path.join(logdir, name) #寫入要壓縮文件 fzip.write(fpath) #關閉 fzip.close()
進入目錄解壓,文件路徑如下:
可以看到,我們將整個目錄添加到壓縮文件中,其實我們更想做的是logs/*.log;
對代碼進行修改:
logdir = '/home/linux/logs' zipname = '/home/linux/logs.zip' import zipfile #創(chuàng)建zip對象, fzip = zipfile.ZipFile(zipname, 'w', zipfile.ZIP_DEFLATED) #遍歷要壓縮目錄 flist = os.listdir(logdir) #獲取壓縮目錄名稱 basename = os.path.basename(logdir) for name in flist: fpath = os.path.join(logdir, name) arcname = os.path.join(basename, name) #寫入要壓縮文件,并添加歸檔文件名稱 fzip.write(fpath, arcname=arcname) #關閉 fzip.close()
壓縮之后,解壓縮內容:
這個才是我們想要的。
2.獲取壓縮包信息
打開壓縮包:
frzip = zipfile.ZipFile(zipname, 'r', zipfile.ZIP_DEFLATED):只讀方式打開; frzip.printdir(),顯示壓縮包文件信息 File Name Modified Size logs/1003.log 2019-04-09 10:00:10 17 logs/1001.log 2019-04-09 10:00:06 17 logs/1004.log 2019-04-09 10:00:12 17 logs/1002.log 2019-04-09 10:00:08 17 logs/1000.log 2019-04-09 10:00:04 17 frzip.filelist:記錄壓縮包文件信息,與printdir類似,內容如下: [<ZipInfo filename='logs/1003.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17>, <ZipInfo filename='logs/1001.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17>, <ZipInfo filename='logs/1004.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17>, <ZipInfo filename='logs/1002.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17>, <ZipInfo filename='logs/1000.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17>] frzip.getinfo(name):獲取指定arcname的信息: frzip.getinfo('logs/1003.log') #輸出結果: <ZipInfo filename='logs/1003.log' compress_type=deflate filemode='-rw-r--r--' file_size=17 compress_size=17> frzip.namelist():獲取壓縮文件列表 ['logs/1003.log', 'logs/1001.log', 'logs/1004.log', 'logs/1002.log', 'logs/1000.log']
3 解壓壓縮包
frzip.extract(member, path=None, pwd=None):
解壓縮一個文件到指定目錄;
參數(shù):
member:壓縮包中文件;
path:解壓縮到指定目錄,默認解壓到當前目錄;
frzip.extractall(path=None, members=None, pwd=None):
解壓縮多個文件到指定目錄;
參數(shù):
path:指定的解壓目錄;
members:指定解壓文件,默認解壓全部;
解壓指定文件到指定目錄:
#可以自己定義路徑 zipname = '/home/linux/logs.zip' extractpath = '/home/linux/1' #注意壓縮格式選擇 frzip = zipfile.ZipFile(zipname, 'r', zipfile.ZIP_DEFLATED) extractfile = frzip.namelist() if len(extractfile): extname = extractfile[0] print('extract file:', extname) frzip.extract(extractfile[0], extractpath) frzip.close()
輸出結果:extract file: logs/1003.log
,在extractpath目錄下有l(wèi)og文件;
使用frzip.extractall將所有文件解壓到指定目錄:
#可以自己定義路徑 zipname = '/home/linux/logs.zip' extractpath = '/home/linux/1' #注意壓縮格式選擇 frzip = zipfile.ZipFile(zipname, 'r', zipfile.ZIP_DEFLATED) #將所有文件加壓縮到指定目錄 frzip.extractall(extractpath) frzip.close()
除了zipfile還有其它模塊:
import gzip; import tarfile;
這些模塊使用方式都類似,后面文章中我們在詳解講解。
總結
以上所述是小編給大家介紹的python解壓縮文件詳解,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧!
相關文章
pytorch查看通道數(shù) 維數(shù) 尺寸大小方式
這篇文章主要介紹了pytorch查看通道數(shù) 維數(shù) 尺寸大小方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05一步步教你用python連接oracle數(shù)據(jù)庫
oracle作為最強大的數(shù)據(jù)庫,Python也提供了足夠的支持。不過與其他數(shù)據(jù)庫略有不同,下面這篇文章主要給大家介紹了關于如何使用python連接oracle數(shù)據(jù)庫的相關資料,需要的朋友可以參考下2023-04-04Python+tkinter使用40行代碼實現(xiàn)計算器功能
這篇文章主要為大家詳細介紹了Python+tkinter使用40行代碼實現(xiàn)計算器功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01針對Pandas的總結以及數(shù)據(jù)讀取_pd.read_csv()的使用詳解
這篇文章主要針對Pandas總結以及數(shù)據(jù)讀取_pd.read_csv()的使用詳解做出了實例,講解非常全面,值得收藏,需要的朋友可以參考下2023-03-03