python解壓zip包中文亂碼解決方法
亂碼得原因:
由于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)建
os.mkdir(new_path)
結果正常:

以上就是python解壓zip包中文亂碼解決方法的詳細內(nèi)容,更多關于python 解壓zip包中文亂碼的資料請關注腳本之家其它相關文章!
相關文章
Python unittest如何生成HTMLTestRunner模塊
這篇文章主要介紹了Python unittest如何生成HTMLTestRunner模塊,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-09-09
使用python將excel數(shù)據(jù)導入數(shù)據(jù)庫過程詳解
這篇文章主要介紹了使用python將excel數(shù)據(jù)導入數(shù)據(jù)庫過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08
Python(wordcloud)如何根據(jù)文本數(shù)據(jù)(.txt文件)繪制詞云圖
這篇文章主要給大家介紹了關于Python(wordcloud)如何根據(jù)文本數(shù)據(jù)(.txt文件)繪制詞云圖的相關資料,詞云Wordcloud是文本數(shù)據(jù)的一種可視化表示方式,它通過設置不同的字體大小或顏色來表現(xiàn)每個術語的重要性,需要的朋友可以參考下2024-05-05

