如果正文或 HTTP 响应是使用 gzip、compress 或 deflate 压缩的,我将使用此函数来解压缩它。
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”转换为类似字节的对象?
原文由 Dan 发布,翻译遵循 CC BY-SA 4.0 许可协议
它是一个类似文件的对象。阅读它们:
如果来自
body
的数据太大而无法读入内存,您需要重构代码并使用zlib.decompressobj
而不是zlib.decompress
.