利用python解壓zip包時出現(xiàn)中文亂碼如何解決-創(chuàng)新互聯(lián)

這篇文章給大家介紹利用python解壓zip包時出現(xiàn)中文亂碼如何解決,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

站在用戶的角度思考問題,與客戶深入溝通,找到安岳網(wǎng)站設(shè)計與安岳網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、主機域名、網(wǎng)站空間、企業(yè)郵箱。業(yè)務覆蓋安岳地區(qū)。

亂碼得原因:

由于ZipFile模塊導出遇到中文解碼不對,windows上會出現(xiàn),linux是否會出現(xiàn)不知道沒測試過。

解決方式:

1. 搞個文件名引射表(不太方便,少量文件夾套用時候還可以)

2. 修改源碼解碼格式(不太方便,自己搞了一下,之后報其他錯誤)

3. 自己寫入文件,自己創(chuàng)建文件夾(推薦)

自己創(chuàng)建的寫法:

with zipfile.ZipFile(file=zip_save_path, mode='r') as zf:
      # 解壓到指定目錄,首先創(chuàng)建一個解壓目錄
      os.mkdir(unzip_dir_path)
      for old_name in zf.namelist():
        # 獲取文件大小,目的是區(qū)分文件夾還是文件,如果是空文件應該不好用。
        file_size = zf.getinfo(old_name).file_size
        # 由于源碼遇到中文是cp437方式,所以解碼成gbk,windows即可正常
        new_name = old_name.encode('cp437').decode('gbk')
        # 拼接文件的保存路徑
        new_path = os.path.join(unzip_dir_path, new_name)
        # 判斷文件是文件夾還是文件
        if file_size > 0:
          # 是文件,通過open創(chuàng)建文件,寫入數(shù)據(jù)
          with open(file=new_path, mode='wb') as f:
            # zf.read 是讀取壓縮包里的文件內(nèi)容
            f.write(zf.read(old_name))
        else:
          # 是文件夾,就創(chuàng)建

關(guān)于利用python解壓zip包時出現(xiàn)中文亂碼如何解決就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

本文標題:利用python解壓zip包時出現(xiàn)中文亂碼如何解決-創(chuàng)新互聯(lián)
分享地址:http://bm7419.com/article16/gjsdg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務、動態(tài)網(wǎng)站小程序開發(fā)、網(wǎng)站策劃服務器托管響應式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化