压缩文件字节流 解压为 原始文件字节流

该博客展示了如何在Python中使用`zipfile`模块从字节流中解压ZIP文件,并详细打印出每个文件的元信息,包括文件名、位置偏移、原始文件大小和压缩后的大小。示例代码中,还演示了如何从URL下载ZIP文件内容并进行处理。
import zipfile  # 无法解压rar、7z等压缩格式
from io import BytesIO


def bytes_zip_to_bytes_content(bytes_zip_content):
    zip_file = BytesIO(bytes_zip_content)  # 相当于with open('/.../file.zip') as zip_file:
    f = zipfile.ZipFile(file=zip_file)
    for f_name in f.namelist():
        file_bytes = f.read(f_name)
        file_info = f.getinfo(f_name)
        print(f'文件名{f_name.encode("cp437").decode("gb18030")}')  # 中文文件名防止乱码
        print(f'文件位置偏移{file_info.header_offset}')
        print(f'原始文件大小{file_info.file_size}')
        print(f'原始字节流大小{len(bytes_zip_content)}应该约等于压缩文件大小{file_info.compress_size}')
        yield file_bytes

if __name__ == "__main__":
    import requests
    
    r = requests.get(url='http://......file.zip')  # 下载压缩文件
    bytes_zip_content = r.content  # 压缩文件字节流
    bytes_zip_to_bytes_content(bytes_zip_content)

 

参考资料:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值