python中zipfile与gzip函数使用及报错

import zipfile

for path in ret:
    print(path)
    # 读取文件
    # with open(path, 'r') as f:
    with zipfile.ZipFile(path, "r") as myzip:
    # with gzip.open(path, 'r') as f:

        i = 1
        first_file_name = myzip.namelist()[0]
        f = myzip.open(first_file_name)
        for line in f:
            allname = line.decode().strip('\n')
           
        myzip.close()
        f.close()

读完一定要关闭,不然会占用很大的内存,也会造成不安全因素,虽然不close不会报错,但是这样搞不对。zipfile要先生成一个Zipfile对象,然后显示压缩包里的文件名称,然后用open函数读取文件名称再读内容。如果不用open函数直接for line in f:就会报错说类型错误不可迭代TypeError: 'ZipFile' object is not iterable。但是gzip不用,直接都进来循环就行了,下边是gzip读取方法。



if path.find(".gz") >= 0:
    with gzip.open(path, 'r') as f:
       for line in f:

           # 文件中每行的数据
           allname = line.decode().strip('\n')
       f_out.close()

f_out.close()


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值