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

Python使用tarfile模塊實(shí)現(xiàn)免費(fèi)壓縮解壓

 更新時(shí)間:2024年03月22日 09:51:55   作者:景天科技苑  
Python自帶的tarfile模塊可以方便讀取tar歸檔文件,厲害的是可以處理使用gzip和bz2壓縮歸檔文件tar.gz和tar.bz2,這篇文章主要介紹了Python使用tarfile模塊實(shí)現(xiàn)免費(fèi)壓縮解壓,需要的朋友可以參考下

tarfile 壓縮模塊

Python自帶的tarfile模塊可以方便讀取tar歸檔文件,厲害的是可以處理使用gzip和bz2壓縮歸檔文件tar.gz和tar.bz2。
與tarfile對(duì)應(yīng)的是zipfile模塊,zipfile是處理zip壓縮的。
zipfile使用的是gzip格式壓縮,但是tarfile可以使用壓縮效率更好的bz2格式
請(qǐng)注意:os.system(cmd)可以使Python腳本執(zhí)行命令,當(dāng)然包括:tar -czf *.tar.gz *,tar -xzf *.tar.gz,unzip等,也可以解決問(wèn)題。

壓縮模塊-tarfile(后綴為.tar | .tar.gz | .tar.bz2)
#bz2模式的壓縮文件較小 根據(jù)電腦的不同會(huì)差生不同的結(jié)果 (理論上:bz2壓縮之后更小,按實(shí)際情況為標(biāo)準(zhǔn))

w 單純的套一個(gè)后綴 打包
w:bz2 采用bz2算法 壓縮
w:gz 采用gz算法 壓縮

tarfile的語(yǔ)法格式

(1)打開(kāi)/創(chuàng)建壓縮包

tarfile.open(name=None, mode=‘r’, fileobj=None, bufsize=10240, **kwargs)
mode:文件打開(kāi)模式,默認(rèn)為‘r’;tarfile模塊的打開(kāi)模式有如下:

(2)壓縮文件

#1.open(‘路徑包名’,‘模式’,‘字符編碼’) 創(chuàng)建或者打開(kāi)文件
#2.add(路徑文件,arcname=“別名”) 向壓縮文件中添加文件
#3,close() 關(guān)閉文件

(3)解壓文件

#1.open(‘路徑包名’,‘模式’,‘字符編碼’) 讀模式打開(kāi)文件
#2.extractall(路徑) 解壓所有文件到某個(gè)路徑下
#extract(文件,路徑) 解壓指定的某個(gè)文件到某個(gè)路徑下
#3.close() 關(guān)閉壓縮文件

(4)追加文件

open() 追加模式 a: 打開(kāi)壓縮文件 正常添加即可

(5)查看壓縮包中的內(nèi)容

getnames()

import tarfile
# (1) 壓縮文件
# 1.只是單純的打包.
# 創(chuàng)建壓縮包
tf = tarfile.open("ceshi0930_0.tar","w",encoding="utf-8")
# 寫(xiě)入文件
"""add(路徑,別名)"""
tf.add("/bin/chown","chown")
tf.add("/bin/cp","cp")
tf.add("/bin/dash","tmp/dash")
# 關(guān)閉文件
tf.close() # 378880
# 2.使用gz算法壓縮
tf = tarfile.open("ceshi0930_1.tar.gz","w:gz",encoding="utf-8")
# 寫(xiě)入文件
"""add(路徑,別名)"""
tf.add("/bin/chown","chown")
tf.add("/bin/cp","cp")
tf.add("/bin/dash","tmp/dash")
# 關(guān)閉文件
tf.close() # 180413
# 3.使用bz2算法壓縮
tf = tarfile.open("ceshi0930_2.tar.bz2","w:bz2",encoding="utf-8")
# 寫(xiě)入文件
"""add(路徑,別名)"""
tf.add("/bin/chown","chown")
tf.add("/bin/cp","cp")
tf.add("/bin/dash","tmp/dash")
# 關(guān)閉文件
tf.close() # 163261

#(2) 解壓文件

tf = tarfile.open(“ceshi0930_1.tar.gz”,“r”,encoding=“utf-8”)
“”" extract(文件,路徑) 解壓?jiǎn)蝹€(gè)文件"“”
tf.extract(“chown”,“ceshi0930_1”)
“”" extract(路徑) 解壓所有文件"“”
tf.extractall(“ceshi0930_1_2”)
tf.close()

解壓?jiǎn)蝹€(gè)文件,第一個(gè)參數(shù)壓縮文件別名,第二個(gè)是要解壓到的路徑

解壓全部文件

#(3) 追加文件
對(duì)已經(jīng)壓縮過(guò)的包無(wú)法進(jìn)行追加文件,只能是沒(méi)有壓縮過(guò)的包進(jìn)行追加文件
針對(duì)已存在的壓縮包,w追加的話,是把原來(lái)的文件給替換了,壓縮包只剩下最后一次追加的文件. 使用a模式,追加已存在的壓縮包,報(bào)錯(cuò)
如果第一次使用a模式,可以一直使用a模式追加
也就是只能追加沒(méi)壓縮過(guò)的包

tf = tarfile.open(“ceshi0930_0.tar”,“a”,encoding=“utf-8”)
tf.add(“/bin/mkdir”,“mkdir”)
tf.close()

使用w模式,是覆蓋

解壓后,只剩下一個(gè)

是用a模式,原壓縮文件存在的話,報(bào)錯(cuò)

第一次使用a模式打包的,可以一直用a模式追加

使用with進(jìn)行改造

with tarfile.open(“ceshi0930_0.tar”,“a”,encoding=“utf-8”) as tf:
tf.add(“/bin/mkdir”,“mkdir234”)

#(4) 查看文件,返回的是個(gè)列表

with tarfile.open(“ceshi0930_0.tar”,“r”,encoding=“utf-8”) as tf:
lst = tf.getnames()
print(lst)

####追加文件到壓縮包中在壓縮

import os,shutil
"""
1.把已經(jīng)壓縮的包進(jìn)行解壓
2.把要追加的內(nèi)容放進(jìn)去
3.過(guò)濾文件重新壓縮
"""
# 記錄壓縮包所在的絕對(duì)路徑
pathvar1 = os.path.abspath("ceshi0930_2.tar.bz2")
# 要解壓到哪個(gè)文件夾中(絕對(duì)路徑)
pathvar2 = os.path.join(  os.getcwd() , "ceshi0930_2"  )
print(pathvar1)# /mnt/hgfs/python32_gx/day16/ceshi0930_2.tar.bz2
print(pathvar2)# /mnt/hgfs/python32_gx/day16/ceshi0930_2
# 1.把已經(jīng)壓縮的包進(jìn)行解壓
with tarfile.open(pathvar1,"r",encoding="utf-8") as tf:
    tf.extractall(pathvar2)
# 2.把要追加的內(nèi)容放進(jìn)去
shutil.copy("/bin/echo" , pathvar2)
# 3.過(guò)濾文件重新壓縮
# 查看文件夾當(dāng)中有什么文件
lst = os.listdir(pathvar2)
print(lst) # ['chown', 'cp', 'echo', 'tmp']
with tarfile.open(pathvar1,"w:bz2",encoding="utf-8") as tf:
    for i in lst:
        if i != "chown":
            # 拼湊成完整的絕對(duì)路徑
            abs_path = os.path.join(pathvar2,i)
            # 剩下的都要壓縮
            """add(路徑,別名)"""
            tf.add(abs_path,i)

到此這篇關(guān)于Python使用tarfile模塊實(shí)現(xiàn)免費(fèi)壓縮解壓的文章就介紹到這了,更多相關(guān)Python壓縮解壓內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python疫情數(shù)據(jù)可視化分析

    Python疫情數(shù)據(jù)可視化分析

    這篇文章主要介紹了Python疫情數(shù)據(jù)可視化分析,本數(shù)據(jù)集主要涉及到全球疫情統(tǒng)計(jì),包括確診、治愈、死亡、時(shí)間、國(guó)家、地區(qū)等信息,需要的朋友可以參考一下
    2022-07-07
  • pygame游戲之旅 游戲中添加顯示文字

    pygame游戲之旅 游戲中添加顯示文字

    這篇文章主要為大家詳細(xì)介紹了pygame游戲之旅的第5篇,教大家如何在游戲中添加顯示文字,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • python使用form-data形式上傳文件請(qǐng)求的方法

    python使用form-data形式上傳文件請(qǐng)求的方法

    Python中的multipart/form-data是一種HTTP POST請(qǐng)求的數(shù)據(jù)格式,用于上傳文件或二進(jìn)制數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于python使用form-data形式上傳文件請(qǐng)求的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • Python網(wǎng)絡(luò)編程之ZeroMQ知識(shí)總結(jié)

    Python網(wǎng)絡(luò)編程之ZeroMQ知識(shí)總結(jié)

    這篇文章主要介紹了Python網(wǎng)絡(luò)編程之ZeroMQ知識(shí)總結(jié),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 在Python的Django框架中用流響應(yīng)生成CSV文件的教程

    在Python的Django框架中用流響應(yīng)生成CSV文件的教程

    這篇文章主要介紹了在Python的Django框架中用流響應(yīng)生成CSV文件的教程,作者特別講到了防止CSV文件中的中文避免出現(xiàn)亂碼等問(wèn)題,需要的朋友可以參考下
    2015-05-05
  • python Tkinter是什么

    python Tkinter是什么

    大家好,本篇文章主要講的是 python Tkinter是什么,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • Python實(shí)現(xiàn)APP自動(dòng)化發(fā)微信群消息的示例代碼

    Python實(shí)現(xiàn)APP自動(dòng)化發(fā)微信群消息的示例代碼

    本文主要介紹了Python實(shí)現(xiàn)APP自動(dòng)化發(fā)微信群消息的示例代,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下碼
    2022-01-01
  • 使用celery和Django處理異步任務(wù)的流程分析

    使用celery和Django處理異步任務(wù)的流程分析

    Celery是 一個(gè)專注于實(shí)時(shí)處理的任務(wù)隊(duì)列,它還支持任務(wù)調(diào)度。 Celery快速,簡(jiǎn)單,高度可用且靈活。這篇文章主要介紹了使用celery和Django處理異步任務(wù)的流程分析,需要的朋友可以參考下
    2020-02-02
  • Python繪制可以表示點(diǎn)密度的散點(diǎn)圖得方法

    Python繪制可以表示點(diǎn)密度的散點(diǎn)圖得方法

    本文介紹基于Python語(yǔ)言的matplotlib模塊,對(duì)Excel表格文件中的指定數(shù)據(jù),加以密度散點(diǎn)圖繪制的方法,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下
    2024-05-05
  • Python Pandas模塊實(shí)現(xiàn)數(shù)據(jù)的統(tǒng)計(jì)分析的方法

    Python Pandas模塊實(shí)現(xiàn)數(shù)據(jù)的統(tǒng)計(jì)分析的方法

    在上一篇講了幾個(gè)常用的“Pandas”函數(shù)之后,今天小編就為大家介紹一下在數(shù)據(jù)統(tǒng)計(jì)分析當(dāng)中經(jīng)常用到的“Pandas”函數(shù)方法,希望能對(duì)大家有所收獲,需要的朋友可以參考下
    2021-06-06

最新評(píng)論