1.Python--zipfile压缩ZIP文件:

1.Python--zipfile压缩ZIP文件:

import zipfile
f = zipfile.ZipFile(target, 'w', zipfile.ZIP_DEFLATED)
f.write(filename, file_url)
f.close()

其中

target:是压缩后要保存的文件名

ZIP_DEFLATED:表示压缩,

ZIP_STORE:表示只打包,不压缩。(这个Linux中的gz跟tar格式有点类似)

write方法:

  如果只有一个参数filename的话,表示把你filename所带的路径全部压缩到zip文件中。

  如果带两个参数,表示把filename路径中的那个file压缩一下并且存放到file_url中,中间没有增加任何的文件夹。(如果把文件放到根目录,请把file_url填为被压缩的文件名)

  如果要压缩很多的文件,循环的write每个文件就ok了

最后关闭文件close。

2.Python--zipfile解压ZIP文件:

f = zipfile.ZipFile(tatgert,'r')
    for file in f.namelist(): 
      #f.namelist()返回列表,列表中的元素为压缩文件中的每个文件  
        f.extract(file,"temp/")

target是压缩文件的路径

循环访问该压缩文件中的文件,并且一个一个file的解压到对应的"temp\"文件夹中

gzip实现压缩及解压

gzip块主要支持打开对应格式的压缩文件,并可以完成对压缩文件的读出和写入操作。压缩文件被打开后,可以使用文件对象一样的方法,如read、readline、readlines、write、writelines等。

1.Python--gzip压缩ZIP文件:

import gzip
f_src = open("data.txt", "rb") #打开文件
f_tar= gzip.open("data.txt.gz", "wb")#创建压缩文件对象f_tar.writelines(f_src)
f_tar.close()
f_src.close()
import gzip 
g = gzip.GzipFile(filename="", mode="wb", compresslevel=9, fileobj=open('sitemap.log.gz', 'wb'))
g.write(open('d:\\test\\sitemap.xml').read())
g.close()

其中,filename参数是压缩文件内文件的名字,为空也可以,不修改。fileobj是生成的压缩文件对象,它的路径名称等。最后是把文件写入gzip文件中去,再关闭操作连接。

2.Python--gzip解压ZIP文件:

import gzip
f = gzip.open("test.gz", 'rb')        #打开压缩文件对象
f_out=open("data.txt","w")              #打开解压后内容保存的文件
file_content = f.read()                #读取解压后文件内容
f_out.write(file_content.decode("utf-8"))     #写入新文件当中
print(file_content)                  #打印读取内容
f.close()
f_out.close()
g = gzip.GzipFile(mode="rb", fileobj=open('c:\\test\\abc.gz', 'rb'))
open(r"d:\\haha.xml", "wb").write(g.read())

使用的时候注意,函数方法的大小写一点要看仔细,如果gzip文件是这种形式的:*.tar.gz,证明先是由tar命令压缩后,后再由 gzip压缩的,需要先用解压缩tar文件,再用gzip模块解压缩。其实,现在很多网页为了提高浏览器端用户的访问速度,和搜索引擎爬虫抓取的速度,都在使用gzip压缩。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区),文章链接,文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:[email protected]进行举报,并提供相关证据,一经查实

你可能感兴趣的:(python)