如果使用gzip,compress或deflate压缩了正文或HTTP响应,我正在使用此函数对其进行解压缩。
def uncompress_body(self, compression_type, body):
if compression_type == 'gzip' or compression_type == 'compress':
return zlib.decompress(body)
elif compression_type == 'deflate':
compressor = zlib.compressobj(9, zlib.DEFLATED, -zlib.MAX_WBITS)
compressed = compressor.compress(body)
compressed += compressor.flush()
return base64.b64encode(compressed)
return body
但是python会抛出此错误消息。
TypeError: a bytes-like object is required, not '_io.BytesIO'
在此行:
return zlib.decompress(body)
从本质上讲,如何将'_io.BytesIO'转换为类似字节的对象?
谢谢
答案 0 :(得分:4)
如果您先写入对象,请确保在读取之前重置流:
>>> b = io.BytesIO()
>>> image = PIL.Image.open(path_to_image)
>>> image.save(b, format='PNG')
>>> b.seek(0)
>>> b.read()
b'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x06\xcf\x00\x00\x03W\x08\x02\x00'
或直接通过getvalue
>>> b.getvalue()
b'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x06\xcf\x00\x00\x03W\x08\x02\x00'
答案 1 :(得分:3)
这是一个类似文件的对象。阅读它们:
>>> b = io.BytesIO(b'hello')
>>> b.read()
b'hello'
如果来自body
的数据太大而无法读入内存,则需要重构代码并使用zlib.decompressobj
而不是zlib.decompress
。