欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python3壓縮和解壓文件案例總結(jié)

 更新時(shí)間:2023年02月15日 08:40:42   作者:cui_yonghua  
壓縮和解壓縮是日常常用的操作,不管是windows上圖形界面的操作,還是linux上用命令來(lái)進(jìn)行壓縮解壓縮,總的而言都還是比較方便的,本文通過(guò)案例代碼講解了python3壓縮和解壓文件的方法,

python3壓縮和解壓文件

1、tar壓縮和解壓

import tarfile
from pathlib import PurePath
path = PurePath(".") / "test"

zip_path = path / "123.tar.gz"
file_path = path / "123.txt"

# 壓縮
# w:gz 寫(xiě)入代表gz壓縮,還有其他用法
with tarfile.open(zip_path, "w:gz") as tar:
    tar.add(file_path, arcname=file_path.name)

# 解壓
with tarfile.open(zip_path, "r:gz") as tar:
    tar.extractall(path / "1123")

2、7z壓縮和解壓

import py7zr  # 需要先安裝:pip install py7zr
import os
from pathlib import Path

path = Path(".") / "test"
zip_path = path / "123.7z"
file_path = path / "123.txt"

# 壓縮
with py7zr.SevenZipFile(zip_path, 'w') as z:
    z.writeall(file_path, arcname=os.path.basename(file_path))

# 解壓
with py7zr.SevenZipFile(zip_path, mode='r') as z:
    z.extractall()

3、zip寫(xiě)入壓縮和解壓

from zipfile import ZipFile
from pathlib import PurePath

path = PurePath(".") / "test"

zip_path = path / "123.zip"
file_path = path / "123.txt"

# 這里的mode, w是寫(xiě)入,r是讀取, a是追加
# write寫(xiě)入的是文件的路徑
with ZipFile(zip_path, "w") as f:
    f.write(file_path)  # 注意這里寫(xiě)入的文件的路徑會(huì)和file_path保持一致
    # 建議用下面這一步
    f.write(file_path, arcname=file_path.name)  # file_path.name等同于os.path.basename

# 解壓文件
with ZipFile(zip_path, "r") as f:
    print(f.namelist())  # 打印壓縮包里的文件
    f.extractall('out_path')  # out_path解壓位置

4、gzip寫(xiě)入壓縮和解壓

import gzip
# 寫(xiě)
filepath = f"file.txt.gz"
content = "Hello World"
with gzip.open(filepath, 'wt') as f:
    f.write(content)

# 讀
with gzip.open(filepath, 'rt') as f:
    content_read = f.read()
print(content_read)

擴(kuò)展:Python3用代碼實(shí)現(xiàn)壓縮與解壓

一、說(shuō)明

壓縮和解壓縮是日常常用的操作,不管是windows上圖形界面的操作,還是linux上用命令來(lái)進(jìn)行壓縮解壓縮,總的而言都還是比較方便的。

但用代碼來(lái)實(shí)現(xiàn)就沒(méi)做過(guò),近期也得實(shí)現(xiàn)代碼壓縮與解壓縮操作,所以就抽時(shí)間來(lái)研究一下。

二、zip文件壓縮和解壓縮實(shí)現(xiàn)

import os
import zipfile


# 函數(shù)功能是zip_file_list所有文件,和zip_dir_list所有目錄下的所有文件,被壓縮到一個(gè)zip_file_name的壓縮文件中
def my_zip_function(zip_file_name, zip_file_list=[], zip_dir_list=[]):
    # 壓縮文件最后需要close,為了方便我們直接用with
    with zipfile.ZipFile(zip_file_name, "w") as zip_obj:
        # 壓縮文件
        for tmp_file in zip_file_list:
            zip_obj.write(tmp_file)
        # 壓縮目錄
        for tmp_dir in zip_dir_list:
            # zipfile沒(méi)有直接壓縮目錄的功能,要壓縮目錄只能遍歷目錄一個(gè)一個(gè)文件壓。
            for root, dirs, files in os.walk(tmp_dir):
                # 如果想要目錄為空時(shí)仍將該目錄壓縮進(jìn)去,該目錄也要壓縮一遍;反之請(qǐng)將以下行注釋掉
                zip_obj.write(root)
                for tmp_file in files:
                    # 拼接文件完整目錄,不然只用文件名代碼找不到文件
                    tmp_file_path = os.path.join(root, tmp_file)
                    zip_obj.write(tmp_file_path)

# 函數(shù)功能是遍歷壓縮文件中的所有文件
def my_traversal_zip_function(zip_file_name):
    with zipfile.ZipFile(zip_file_name, "r") as zip_obj:
        # 返回結(jié)果是一個(gè)ZipInfo列表
        # 如果在壓縮時(shí)顯示壓縮目錄,則目錄也作為一個(gè)單獨(dú)的ZipInfo呈現(xiàn)在列表中;反之則沒(méi)有目錄的ZipInfo
        all_file_list = zip_obj.infolist()
        for tmp_file in all_file_list:
            print(tmp_file.filename)
            # 還可以在不解壓的情況下直接讀取文件的內(nèi)容
            # 可以通過(guò)ZipInfo.is_dir()來(lái)區(qū)分是文件還是目錄
            # if not tmp_file.is_dir():
            #     with zip_obj.open(tmp_file) as zip_fd:
            #         print(zip_fd.read())

# 函數(shù)的功能是將壓縮文件直接解壓
def my_unzip_function(zip_file_name, path="."):
    with zipfile.ZipFile(zip_file_name, "r") as zip_obj:
        zip_obj.extractall(path=path)

if __name__ == "__main__":
    zip_file_name = "test_zip.zip"
    # 自己在測(cè)試時(shí)要先自行創(chuàng)建好要壓縮的文件和目錄
    zip_file_list = ["test_tar_file1.txt", "test_tar_file2.txt"]
    zip_dir_list = ["test_tar_dir"]
    my_zip_function(zip_file_name, zip_file_list, zip_dir_list)
    my_traversal_zip_function(zip_file_name)
    # my_unzip_function(zip_file_name, path=".")

三、tar文件的壓縮與解壓縮實(shí)現(xiàn)

除了直接的.tar文件,還包括.tar.gz/.tar.bz2/.tar.xz等格式文件的壓縮與解壓縮實(shí)現(xiàn)。

'''
學(xué)習(xí)中遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:857662006
尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書(shū)!
'''
import os
import tarfile


# 函數(shù)功能是tar_file_list所有文件,和tar_dir_list所有目錄下的所有文件,被壓縮到一個(gè)tar_file_name的壓縮文件中
def my_tar_function(tar_file_name, tar_file_list=[], tar_dir_list=[], model="w"):
    # 本來(lái)也應(yīng)該是tarfile.TarFile(tar_file_name, model)來(lái)創(chuàng)建的,但TarFile不支持"r:gz"等擴(kuò)展形式
    # 壓縮文件最后需要close,為了方便我們直接用with
    with tarfile.open(tar_file_name, model) as tar_obj:
        # 壓縮文件
        for tmp_file in tar_file_list:
            tar_obj.add(tmp_file)
        # 壓縮目錄。和zipfile相比tarfile允許直接壓縮目錄,而不需要去遍歷目錄一個(gè)個(gè)文件壓
        for tmp_dir in tar_dir_list:
            tar_obj.add(tmp_dir)


# 函數(shù)功能是遍歷壓縮文件中的所有文件
def my_traversal_tar_function(tar_file_name, model="r"):
    with tarfile.open(tar_file_name, model) as tar_obj:
        # 返回結(jié)果是一個(gè)TarInfo列表
        all_file_list = tar_obj.getmembers()
        for tmp_file in all_file_list:
            print(tmp_file.name)
            # 還可以在不解壓的情況下直接讀取文件的內(nèi)容
            # 可以通過(guò)TarInfo.isdir()來(lái)區(qū)分是文件還是目錄
            # if not tmp_file.isdir():
            #     # 相當(dāng)于zip的open,并不會(huì)把文件給解壓出來(lái)
            #     tar_fd = tar_obj.extractfile(tmp_file)
            #     print(tar_fd.read())

# 函數(shù)的功能是將壓縮文件直接解壓
def my_untar_function(tar_file_name, path=".", model="r"):
    with tarfile.open(tar_file_name, model) as tar_obj:
        tar_obj.extractall(path=path)

if __name__ == "__main__":
    # 自己在測(cè)試時(shí)要先自行創(chuàng)建好要壓縮的文件和目錄
    tar_file_list = ["test_tar_file1.txt", "test_tar_file2.txt"]
    tar_dir_list = ["test_tar_dir"]
    tar_file_name = "test_tar.tar"
    # 在.tar基礎(chǔ)上,tarfile還支持gz/bz2/xz的壓縮,只要在原來(lái)打開(kāi)模式的基礎(chǔ)上使用:或|接上壓縮方法即可,如"r:gz"
    # 特別的,如果是讀取文件,可以使用"r:*"來(lái)指示嘗試以任意格式讀取
    open_model = "w"
    # open_model = "w:gz"
    my_tar_function(tar_file_name, tar_file_list, tar_dir_list, model=open_model)
    open_model = "r"
    # open_model = "r:*"
    my_traversal_tar_function(tar_file_name, model=open_model)
    # open_model = "r:*"
    # my_untar_function(tar_file_name, path=".", model=open_model)

到此這篇關(guān)于python3壓縮和解壓文件案例總結(jié)的文章就介紹到這了,更多相關(guān)python壓縮和解壓文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python3 venv搭建輕量級(jí)虛擬環(huán)境的步驟(圖文)

    Python3 venv搭建輕量級(jí)虛擬環(huán)境的步驟(圖文)

    這篇文章主要介紹了Python3 venv搭建輕量級(jí)虛擬環(huán)境的步驟(圖文),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Python locust工具使用詳解

    Python locust工具使用詳解

    這篇文章主要介紹了Python locust工具使用詳解,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-03-03
  • 用Python爬取2022春節(jié)檔電影信息

    用Python爬取2022春節(jié)檔電影信息

    大家好,本篇文章主要講的是用Python爬取2022春節(jié)檔電影信息,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Python元組拆包和具名元組解析實(shí)例詳解

    Python元組拆包和具名元組解析實(shí)例詳解

    這篇文章主要介紹了Python元組拆包和具名元組解析,下面的內(nèi)容就圍繞元組作為數(shù)據(jù)記錄屬性展開(kāi),并介紹帶字段名的具名元組函數(shù)namedtuple,列表屬性不再本文中敘述。
    2018-03-03
  • python中文件的創(chuàng)建與寫(xiě)入實(shí)戰(zhàn)代碼

    python中文件的創(chuàng)建與寫(xiě)入實(shí)戰(zhàn)代碼

    這篇文章主要給大家介紹了關(guān)于python中文件的創(chuàng)建與寫(xiě)入的相關(guān)資料,在Python中文件寫(xiě)入提供了不同的模式和方法來(lái)滿足不同的需求,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • python實(shí)例小練習(xí)之Turtle繪制南方的雪花

    python實(shí)例小練習(xí)之Turtle繪制南方的雪花

    Turtle庫(kù)是Python語(yǔ)言中一個(gè)很流行的繪制圖像的函數(shù)庫(kù),想象一個(gè)小烏龜,在一個(gè)橫軸為x、縱軸為y的坐標(biāo)系原點(diǎn),(0,0)位置開(kāi)始,它根據(jù)一組函數(shù)指令的控制,在這個(gè)平面坐標(biāo)系中移動(dòng),從而在它爬行的路徑上繪制了圖形
    2021-09-09
  • linux下python抓屏實(shí)現(xiàn)方法

    linux下python抓屏實(shí)現(xiàn)方法

    這篇文章主要介紹了linux下python抓屏實(shí)現(xiàn)方法,涉及Python操作屏幕截取的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • Matplotlib繪圖基礎(chǔ)之文本標(biāo)注詳解

    Matplotlib繪圖基礎(chǔ)之文本標(biāo)注詳解

    Matplotlib?文本和標(biāo)注可以為數(shù)據(jù)和圖形之間提供額外的信息,幫助觀察者更好地理解數(shù)據(jù)和圖形的含義,下面就將通過(guò)示例依次介紹文本和標(biāo)注的常用使用方式
    2023-08-08
  • Python的哈希hashlib模塊詳細(xì)解讀

    Python的哈希hashlib模塊詳細(xì)解讀

    這篇文章主要介紹了Python的哈希hashlib模塊詳細(xì)解讀,hashlib是一個(gè)提供字符加密功能的模塊,包含MD5和SHA的加密算法,具體支持md5,sha1, sha224, sha256, sha384, sha512等算法, 該模塊在用戶登錄認(rèn)證方面應(yīng)用廣泛,對(duì)文本加密也很常見(jiàn),需要的朋友可以參考下
    2023-09-09
  • Python?八個(gè)數(shù)據(jù)清洗實(shí)例代碼詳解

    Python?八個(gè)數(shù)據(jù)清洗實(shí)例代碼詳解

    不管你承不承認(rèn),數(shù)據(jù)清洗著實(shí)不是一件簡(jiǎn)單的任務(wù),大多數(shù)情況下這項(xiàng)工作是十分耗時(shí)而乏味的,但它又是十分重要的,本篇文章帶給你八個(gè)實(shí)例代碼
    2022-01-01

最新評(píng)論