Python模塊zipfile原理及使用方法詳解
zipfile是python里用來(lái)做zip格式編碼的壓縮和解壓縮的,由于是很常見(jiàn)的zip格式,所以這個(gè)模塊使用頻率也是比較高的
zipfile里有兩個(gè)非常重要的class, 分別是ZipFile和ZipInfo, 在絕大多數(shù)的情況下,我們只需要使用這兩個(gè)class就可以了。
ZipFile是主要的類(lèi),用來(lái)創(chuàng)建和讀取zip文件
ZipInfo是存儲(chǔ)的zip文件的每個(gè)文件的信息的。
比如要讀取一個(gè)zipfile,這里假設(shè)filename是一個(gè)文件的路徑:
import zipfilez = zipfile.ZipFile(filename, ’r’) # 這里的第二個(gè)參數(shù)用r表示是讀取zip文件,w是創(chuàng)建一個(gè)zip文件for f in z.namelist(): print f
上面的代碼是讀取一個(gè)zip壓縮包里所有文件的名字。z.namelist() 會(huì)返回壓縮包內(nèi)所有文件名的列表。
再看看下面一個(gè):
import zipfilez = zipfile.ZipFile(filename, ’r’)for i in z.infolist(): print i.file_size, i.header_offset
這里使用了z.infolist(), 它返回的就是壓縮包內(nèi)所有文件的信息,就是一個(gè)ZipInfo的列表。一個(gè)ZopInfo對(duì)象中包含了壓縮包內(nèi)一個(gè)文件的信息,其中比較常用的是 filename, file_size, header_offset, 分別為文件名,文件大小,文件數(shù)據(jù)在壓縮包中的偏移。其實(shí)之前的z.namelist()就是讀取的ZopInfo中的filename,組成一個(gè) list返回的。
從壓縮包里解壓縮出一個(gè)文件的方法是使用ZipFile的read方法:
import zipfilez = zipfile.ZipFile(filename, ’r’)print z.read(z.namelist()[0])
這樣就讀取出z.namelist()中的第一個(gè)文件,并且輸出到屏幕,當(dāng)然也可以把它存儲(chǔ)到文件。
下面是創(chuàng)建zip壓縮包的方法:
與讀取的方法其實(shí)很類(lèi)似的:
import zipfile, osz = zipfile.ZipFile(filename, ’w’) # 注意這里的第二個(gè)參數(shù)是w,這里的filename是壓縮包的名字#假設(shè)要把一個(gè)叫testdir中的文件全部添加到壓縮包里(這里只添加一級(jí)子目錄中的文件):if os.path.isdir(testdir): for d in os.listdir(testdir): z.write(testdir+os.sep+d)# close() 是必須調(diào)用的!z.close()
上面的代碼非常的簡(jiǎn)單。
想想還有一個(gè)問(wèn)題,如果我把一個(gè)test/111.txt 添加到壓縮包里之后我希望在包里它放到test22/111.txt怎么辦呢?
其實(shí)這個(gè)就是ZipFile的write方法中第二個(gè)參數(shù)的作用了。只需要這樣調(diào)用:z.write('test/111.txt', 'test22/111.txt')
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 概述IE和SQL2k開(kāi)發(fā)一個(gè)XML聊天程序2. js開(kāi)發(fā)中的頁(yè)面、屏幕、瀏覽器的位置原理(高度寬度)說(shuō)明講解(附圖)3. ASP動(dòng)態(tài)include文件4. CSS百分比padding制作圖片自適應(yīng)布局5. vue跳轉(zhuǎn)頁(yè)面常用的幾種方法匯總6. 不要在HTML中濫用div7. XML入門(mén)的常見(jiàn)問(wèn)題(三)8. XML 非法字符(轉(zhuǎn)義字符)9. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)10. CSS清除浮動(dòng)方法匯總
