使用python怎么實(shí)現(xiàn)一個(gè)壓包功能?針對這個(gè)問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡單易行的方法。
在平度等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都做網(wǎng)站、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需求定制網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站制作,營銷型網(wǎng)站,外貿(mào)營銷網(wǎng)站建設(shè),平度網(wǎng)站建設(shè)費(fèi)用合理。1、概念
壓包是解包的逆過程,用zip函數(shù)實(shí)現(xiàn)。
(1)zip() 函數(shù)用于將可迭代的對象作為參數(shù),將對象中對應(yīng)的元素打包成一個(gè)個(gè)元組,然后返回由這些元組組成的對象(Python3)。
(2)如果各個(gè)迭代器的元素個(gè)數(shù)不一致,則返回列表長度與短的對象相同,利用*號操作符,可以將元組解壓為列表。
先是zip函數(shù)將a b壓包成為一個(gè)可迭代對象,對可迭代對象的每一個(gè)元素((‘a(chǎn)', 1))進(jìn)行解包(i, j = (‘a(chǎn)', 1)),此時(shí)就可以分別調(diào)用i j變量進(jìn)行計(jì)算。
>>> a = [0, 1, 2] >>> b = [1, 2, 3] >>> for i, j in zip(a, b): ... print(i+j) ... 1 3 5
知識點(diǎn)擴(kuò)展
1.Python--gzip壓縮ZIP文件:
import gzip f_src = open("data.txt", "rb") #打開文件 f_tar= gzip.open("data.txt.gz", "wb")#創(chuàng)建壓縮文件對象 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參數(shù)是壓縮文件內(nèi)文件的名字,為空也可以,不修改。fileobj是生成的壓縮文件對象,它的路徑名稱等。最后是把文件寫入gzip文件中去,再關(guān)閉操作連接。
2.Python--gzip解壓ZIP文件:
import gzip f = gzip.open("data.txt.gz", 'rb') #打開壓縮文件對象 f_out=open("data.txt","w") #打開解壓后內(nèi)容保存的文件 file_content = f.read() #讀取解壓后文件內(nèi)容 f_out.write(file_content.decode("utf-8")) #寫入新文件當(dāng)中 print(file_content) #打印讀取內(nèi)容 f.close() f_out.close()
g = gzip.GzipFile(mode="rb", fileobj=open('d:\\test\\sitemap.log.gz', 'rb')) open(r"d:\\haha.xml", "wb").write(g.read())
使用的時(shí)候注意,函數(shù)方法的大小寫一點(diǎn)要看仔細(xì),如果gzip文件是這種形式的:*.tar.gz,證明先是由tar命令壓縮后,后再由 gzip壓縮的,需要先用解壓縮tar文件,再用gzip模塊解壓縮。其實(shí),現(xiàn)在很多網(wǎng)頁為了提高瀏覽器端用戶的訪問速度,和搜索引擎爬蟲抓取的速度,都在使用gzip壓縮。
關(guān)于使用python怎么實(shí)現(xiàn)一個(gè)壓包功能問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。