用Python管理压缩包-创新互联

管理 zip 压缩包

读取zip压缩包内文件列表

Python管理zip主要使用zipfile模块,这个模块里有一个名为 ZipFile 的对象,我们通过将 zip 压缩包的名称传递给这个对象的函数,这样就打开了一个 zip 压缩包并获得一个 ZipFile 的对象,然后使用这个对象的方法去读取 zip 压缩包里的内容。具体如下所示:

创新互联公司从2013年创立,是专业互联网技术服务公司,拥有项目成都网站制作、做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元普定做网站,已为上家服务,为普定各地企业和个人服务,联系电话:028-86922220
import zipfile
first_zip = zipfile.ZipFile('test.zip')
file_list = first_zip.namelist()
print(file_list)

namelist() 是 ZipFile 中的常用方法,除此以外比较常用的方法还有 extract,extractall:

  • namelist:返回一个列表,列表中是 zip 中包含的所有文件和文件夹;
  • extract:从 zip 中提取单个文件
  • extarctall:从 zip 文件中提取所有文件

创建zip压缩包

如果想要创建一个zip格式的压缩文件,必须要以「写」的模式打开 zip 文件,可以是w或a

import zipfile
my_zip = zipfile.ZipFile('test2.zip', 'w')
my_zip.write('serilizer.py')
my_zip.close()

上面的代码是创建了一个名为test2.zip的新zip压缩包,压缩包里包含serilizer.py这个问题件,注意,如果同名压缩包已经存在,使用w模式会删除压缩包内原有的问题件,如果对已有压缩包添加文件的话可以使用a模式

管理tar包

tar 命令一般是在 Linux 系统中创建压缩包,此外 tar 命令也可以创建一个不压缩的 tar 包,仅仅是为了能把多个文件进行打包便于传输。这也就是说,我们在使用 tar 命令的时候,既可以创建普通的 tar 包,也可以创建使用压缩算法压缩过的压缩包。

Python 中使用 tarfile 标准库提供了 tar 命令提供的功能,我们也可以使用它创建一个压缩或者一个非压缩的 tar 包。

创建tar包

import tarfile
with tarfile.open('etc.tar', mode='w') as f:
    f.add('apps.py')

上面的代码中,由于我们是创建一个 tar 包,所以以「写」模式打开 tar 包并得到一个 TarFile 对象,然后使用 TarFile 对象的 add 方法将 test.py 文件添加到 tar 包中。

读取tar包的文件列表

import tarfile
with tarfile.open('etc.tar') as t:
    for member in t.getmembers():
        print(member.name)

上面的代码中,导入 tarfile 库,使用默认的读模式打开 tar 包,tarfile.open() 函数返回一个 TarFile 对象,这个对象表示当前打开的 tar 包,我们可以通过这个对象的方法操作和读取 tar 包中的内容。

tarfile 中有不少函数,其中最常用的有 getnames,extract,extractall 函数:

  • getnames:获取 tar 包中每个文件的对象,是个列表;
  • extract:提取单个文件;
  • extractall:提取所有文件

tarfile 读取和创建压缩包

上面我们用 targfile 创建和读取未压缩的 tar 包,但是一般情况下,我们创建 tar 包的时候都会使用压缩算法进行压缩,以加快传输速度和减少占用的磁盘空间。

使用 tarfile 创建和读取压缩包非常简单,只要在打开文件时指定压缩算法即可。对于 tarfile 的 open 函数,以「打开模式:压缩算法」的形式打开即可。具体如下所示:

创建一个用gzip算法压缩的tar包

import tarfile
with tarfile.open('etc.tar.gz', mode='w:gz') as f:
    f.add('apps.py')

读取一个用gzip算法压缩的tar包

import tarfile
with tarfile.open('test.tar.gz', 'r:gz') as f:
    for member in f.getmembers():
        print(member.name)

参考链接
https://mp.weixin.qq.com/s/mic5BtABQYBxMCxvw6t3Bw

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前文章:用Python管理压缩包-创新互联
转载源于:http://myzitong.com/article/hcdps.html