python tar.gz格式压缩、解压

发布时间:2020-02-13 12:03:11编辑:admin阅读(2389)

    一、压缩

    需求描述

    现在有一个目录,需要将此目录打包成tar.gz文件。因为有一个Django项目,需要用到此功能!

    tar.gz

    目录结构如下:

    ./├── folder
    │   ├── 1.doc
    │   └── 2.txt
    └── packing.py

     

    packing.py 是python程序,需要将folder目录打包成tar.gz文件

     

    packing.py 内容如下:

    #!/usr/bin/env python3
    # coding: utf-8
    import os, tarfile
    
    def make_targz(output_filename, source_dir):
        """
        一次性打包目录为tar.gz
        :param output_filename: 压缩文件名
        :param source_dir: 需要打包的目录
        :return: bool
        """
        try:
            with tarfile.open(output_filename, "w:gz") as tar:
                tar.add(source_dir, arcname=os.path.basename(source_dir))
    
            return True
        except Exception as e:
            print(e)
            return False
    
    make_targz('aa.tar.gz','folder')


    注意:

    空子目录会被打包,如果只打包不压缩,将"w:gz"参数改为"w:"或"w"即可。

     

    执行程序,会在当前目录下生成aa.tar.gz文件 

     

    二、解压

    def untar(fname, dirs):
        """
        解压tar.gz文件
        :param fname: 压缩文件名
        :param dirs: 解压后的存放路径
        :return: bool
        """
        try:
            t = tarfile.open(fname)
            t.extractall(path = dirs)
            return True
        except Exception as e:
            print(e)
            return False
    
    untar('aa.tar.gz','./')


    完整代码如下:

    #!/usr/bin/env python3
    # coding: utf-8
    import os, tarfile
    
    def make_targz(output_filename, source_dir):
        """
        一次性打包目录为tar.gz
        :param output_filename: 压缩文件名
        :param source_dir: 需要打包的目录
        :return: bool
        """
        try:
            with tarfile.open(output_filename, "w:gz") as tar:
                tar.add(source_dir, arcname=os.path.basename(source_dir))
    
            return True
        except Exception as e:
            print(e)
            return False
    
    
    def untar(fname, dirs):
        """
        解压tar.gz文件
        :param fname: 压缩文件名
        :param dirs: 解压后的存放路径
        :return: bool
        """
        try:
            t = tarfile.open(fname)
            t.extractall(path = dirs)
            return True
        except Exception as e:
            print(e)
            return False
    
    # make_targz('aa.tar.gz','folder')
    untar('aa.tar.gz','./')

    执行程序,就会将aa.tar.gz解压到当前文件夹下

     

    三、压缩原理

    把文件的二进制代码压缩,把相邻的0,1代码减少,比如有000000,可以把它变成6个0 的写法60,来减少该文件的空间。

    由于计算机处理的信息是以二进制数的形式表示的,因此压缩软件就是把二进制信息中相同的字符串以特殊字符标记来达到压缩的目的。为了有助于理解文件压缩,请在脑海里想象一幅蓝天白云的图片。对于成千上万单调重复的蓝色像点而言,与其一个一个定义“蓝、蓝、蓝……”长长的一串颜色,还不如告诉电脑:“从这个位置开始存储1117个蓝色像点”来得简洁,而且还能大大节约存储空间。这是一个非常简单的图像压缩的例子。其实,所有的计算机文件归根结底都是以“1”和“0”的形式存储的,和蓝色像点一样,只要通过合理的数学计算公式,文件的体积都能够被大大压缩以达到“数据无损稠密”的效果。总的来说,压缩可以分为有损和无损压缩两种。如果丢失个别的数据不会造成太大的影响,这时忽略它们是个好主意,这就是有损压缩。有损压缩广泛应用于动画、声音和图像文件中,典型的代表就是影碟文件格式mpeg、音乐文件格式mp3和图像文件格式jpg。但是更多情况下压缩数据必须准确无误,人们便设计出了无损压缩格式,比如常见的zip、rar等。压缩软件(compression software)自然就是利用压缩原理压缩数据的工具,压缩后所生成的文件称为压缩包(archive),体积只有原来的几分之一甚至更小。当然,压缩包已经是另一种文件格式了,如果想使用其中的数据,首先得用压缩软件把数据还原,这个过程称作解压缩。常见的压缩软件有winzip、winrar等。

     

    本文参考链接:

    https://www.cnblogs.com/liangqihui/p/9219333.html

    https://www.cnblogs.com/kaituorensheng/p/4493145.html


关键字