pyton
zlib
biblioteka obsługuje :
zlib
Moduł Pythona również je obsługuje.
wybierając windowBits
Ale zlib
może rozpakować wszystkie te formaty:
- do (dekompresji)
deflate
formatu, użyjwbits = -zlib.MAX_WBITS
- do (dekompresji)
zlib
formatu, użyjwbits = zlib.MAX_WBITS
- do (dekompresji)
gzip
formatu, użyjwbits = zlib.MAX_WBITS | 16
Zobacz dokumentację w http://www.zlib.net/manual.html#Advanced (sekcja inflateInit2
)
przykłady
dane testowe:
>>> deflate_compress = zlib.compressobj(9, zlib.DEFLATED, -zlib.MAX_WBITS)
>>> zlib_compress = zlib.compressobj(9, zlib.DEFLATED, zlib.MAX_WBITS)
>>> gzip_compress = zlib.compressobj(9, zlib.DEFLATED, zlib.MAX_WBITS | 16)
>>>
>>> text = '''test'''
>>> deflate_data = deflate_compress.compress(text) + deflate_compress.flush()
>>> zlib_data = zlib_compress.compress(text) + zlib_compress.flush()
>>> gzip_data = gzip_compress.compress(text) + gzip_compress.flush()
>>>
oczywisty test na zlib
:
>>> zlib.decompress(zlib_data)
'test'
test na deflate
:
>>> zlib.decompress(deflate_data)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
zlib.error: Error -3 while decompressing data: incorrect header check
>>> zlib.decompress(deflate_data, -zlib.MAX_WBITS)
'test'
test na gzip
:
>>> zlib.decompress(gzip_data)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
zlib.error: Error -3 while decompressing data: incorrect header check
>>> zlib.decompress(gzip_data, zlib.MAX_WBITS|16)
'test'
dane są również kompatybilne z gzip
modułem:
>>> import gzip
>>> import StringIO
>>> fio = StringIO.StringIO(gzip_data)
>>> f = gzip.GzipFile(fileobj=fio)
>>> f.read()
'test'
>>> f.close()
automatyczne wykrywanie nagłówka (zlib lub gzip)
dodanie 32
do windowBits
spowoduje wykrycie nagłówka
>>> zlib.decompress(gzip_data, zlib.MAX_WBITS|32)
'test'
>>> zlib.decompress(zlib_data, zlib.MAX_WBITS|32)
'test'
używając gzip
zamiast tego
W przypadku gzip
danych z nagłówkiem gzip możesz użyć gzip
modułu bezpośrednio; ale proszę pamiętać, że pod maską , gzip
zastosowań zlib
.
fh = gzip.open('abc.gz', 'rb')
cdata = fh.read()
fh.close()
zlib.decompress(data, 15 + 32)