溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python壓縮和解壓縮模塊之zlib怎么使用

發(fā)布時(shí)間:2022-09-28 14:39:36 來源:億速云 閱讀:233 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了python壓縮和解壓縮模塊之zlib怎么使用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇python壓縮和解壓縮模塊之zlib怎么使用文章都會(huì)有所收獲,下面我們一起來看看吧。

python壓縮和解壓縮模塊之zlib

由于早期的zlib和Python之間不兼容,故推薦1.1.4以后的版本。導(dǎo)入zlib后可以查看版本號

>>> import zlib
>>> zlib.ZLIB_VERSION
'1.2.11'
>>> zlib.ZLIB_RUNTIME_VERSION
'1.2.11'

zlib中封裝了兩對壓縮和解壓的函數(shù)

壓縮解壓
compressdecompress
compressobjdecompressobj

其中compress和decompress比較簡單,二者聲明為

zlib.compress(data, level=-1)
zlib.decompress(data, wbits=MAX_WBITS, bufsize=DEF_BUF_SIZE)

即分別對data進(jìn)行壓縮和解壓。

其中l(wèi)evel為整數(shù),用于指定壓縮等級,決定壓縮后文件的大小,取值為-1到9。

zlib中內(nèi)置了四個(gè)常量,用以表示四種情況。

  壓縮模式
1Z_BEST_SPEED最快速度和最低壓縮率
9Z_BEST_COMPRESSION最慢速度最高壓縮率
0Z_NO_COMPRESSION不壓縮
-1Z_DEFAULT_COMPRESSION一般相當(dāng)于設(shè)壓縮等級為6

解壓函數(shù)中的wbits控制歷史緩沖區(qū)的大?。ɑ蚍Q“窗口大小”)以及所期望的頭部和尾部格式。

默認(rèn)為MAX_WBITS,其取值范圍和含義如下

 包含頭尾 
+8至+15必須窗口尺寸以二為底的對數(shù)。輸入必須包含zlib頭部和尾部。
0必須含頭根據(jù) zlib 頭部自動(dòng)確定窗口大小
−8至−15無頭尾使用wbits絕對值作為窗口大小以二為底的對數(shù)
+24至+31必須包含使用后4個(gè)比特位作為窗口大小以二為底的對數(shù)。
+40 至+47自動(dòng)使用后4個(gè)比特位作為窗口大小以二為底的對數(shù)

bufsize是表示緩沖區(qū)初始大小,默認(rèn)為DEF_MEM_LEVEL,由于在解壓過程中會(huì)自動(dòng)調(diào)節(jié),故不必完全精確。

例如:

>>> x = b'abcdefghijk'*100
>>> x0 = compress(x,0) 
>>> x1 = compress(x,1) 
>>> x9 = compress(x,9) 
>>> print(len(x),len(x0), len(x1), len(x9))
1100 1111 32 29 #無壓縮時(shí)得到的數(shù)據(jù)比原始數(shù)據(jù)還大
>>> d1 = decompress(x9) #解壓縮
>>> d1 == x
True
  • compressobjdecompressobj分別返回一個(gè)壓縮對象和解壓對象。

  • compressobj返回一個(gè) 壓縮對象,用來壓縮內(nèi)存中難以容下的數(shù)據(jù)流,聲明如下

compressobj(level=-1, method=DEFLATED, wbits=MAX_WBITS, memLevel=DEF_MEM_LEVEL, strategy=Z_DEFAULT_STRATEGY[, zdict])

其中l(wèi)evel為壓縮級別,和前文一樣取值為 -1 到 9;method 表示壓縮算法,現(xiàn)在只支持 DEFLATED;memLevel指定內(nèi)部壓縮操作時(shí)所占用內(nèi)存大小。參數(shù)取 1 到 9,默認(rèn)DEF_MEM_LEVEL,取值越大越占內(nèi)存,但速度更快。

wbits 和decompress中相似,但取值范圍更少,默認(rèn)是15(MAX_WBITS)。

參數(shù)范圍如下:

  
+9 至 +15窗口大小以二為底的對數(shù)。 即這些值對應(yīng)著 512 至 32768 的窗口大小。 更大的值會(huì)提供更好的壓縮,同時(shí)內(nèi)存開銷也會(huì)更大。 壓縮輸出會(huì)包含 zlib 特定格式的頭部和尾部。
−9 至 −15絕對值為窗口大小以二為底的對數(shù)。 壓縮輸出僅包含壓縮數(shù)據(jù),沒有頭部和尾部。
+25 至 +31后 4 個(gè)比特位為窗口大小以二為底的對數(shù)。 壓縮輸出包含一個(gè)基本的 gzip 頭部,并以校驗(yàn)和為尾部。
  • strategy 用于調(diào)節(jié)壓縮算法,默認(rèn)即可。

  • zdict 指定預(yù)定義的壓縮字典。是一個(gè)字節(jié)序列,其中包含用戶認(rèn)為要壓縮的數(shù)據(jù)中可能頻繁出現(xiàn)的子序列。頻率高的子序列應(yīng)當(dāng)放在字典的尾部。

除了壓縮和解壓縮,zlib還提供了兩個(gè)數(shù)據(jù)校驗(yàn)的函數(shù),

函數(shù)算法 
zlib.adler32Adler-32校驗(yàn) 
zlib.crc32CRC(循環(huán)冗余)校驗(yàn) 

二者均輸入數(shù)據(jù)和校驗(yàn)起始值,校驗(yàn)起始值value默認(rèn)為1。這兩個(gè)函數(shù)僅為驗(yàn)證數(shù)據(jù)的正確性,均無加密強(qiáng)度,不適合做密碼。

>>> zlib.adler32(b'abcdefghijk')
434701411
>>> zlib.crc32(b'abcdefghijk')
3461812127

python中zlib庫用法

zlib主要用于壓縮與解壓縮

  • 字符串:使用zlib.compress可以壓縮字符串。使用zlib.decompress可以解壓字符串。

  • 數(shù)據(jù)流:壓縮:compressobj,解壓:decompressobj

示例代碼:

import zlib
 
data = 'abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz' \
       'abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz'
print(len(data))
print(data)
 
# 壓縮
compressed_data = zlib.compress(data.encode())  # 注意:這兒要以字節(jié)的形式傳入
print(len(compressed_data))
print(compressed_data)
 
# 解壓
new_data = zlib.decompress(compressed_data).decode()
print(len(new_data))
print(new_data)

運(yùn)行結(jié)果:

python壓縮和解壓縮模塊之zlib怎么使用

示例代碼2:

import zlib
 
 
# 壓縮文件或數(shù)據(jù)
def compress_data(file, zip_file, level=9):
    file = open(file, 'rb')
    zip_file = open(zip_file, 'wb')
    compress = zlib.compressobj(level)
    data = file.read(1024)
    while data:
        zip_file.write(compress.compress(data))
        data = file.read(1024)
    zip_file.write(compress.flush())
    file.close()
    zip_file.close()
 
 
# 解壓文件或數(shù)據(jù)
def decompress_data(zip_file, new_file):
    zip_file = open(zip_file, 'rb')
    new_file = open(new_file, 'wb')
    decompress = zlib.decompressobj()
    data = zip_file.read(1024)
    while data:
        new_file.write(decompress.decompress(data))
        data = zip_file.read(1024)
    new_file.write(decompress.flush())
    zip_file.close()
    new_file.close()
 
 
if __name__ == '__main__':
    file = 'text.txt'
    zip_file = 'text_zip.txt'
    compress_data(file, zip_file)
 
    new_file = 'test_new.txt'
    decompress_data(zip_file, new_file)
    print('end!')

運(yùn)行結(jié)果:

python壓縮和解壓縮模塊之zlib怎么使用

注意:

compressobj返回一個(gè)壓縮對象,用來壓縮不能一下子讀入內(nèi)存的數(shù)據(jù)流。

level 從9到-1表示壓縮等級,其中1最快但壓縮度最小,9最慢但壓縮度最大,0不壓縮,默認(rèn)是-1大約相當(dāng)于與等級6,是一個(gè)壓縮速度和壓縮度適中的level。

關(guān)于“python壓縮和解壓縮模塊之zlib怎么使用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“python壓縮和解壓縮模塊之zlib怎么使用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI