python3 zipfile解压中文乱码问题解决

本文介绍了解决Python的zipfile模块处理含有中文文件名的zip文件时出现乱码的问题。通过手动将文件名从cp437编码转换为gbk编码,解决了中文文件名显示乱码的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文参考自:Python3中zipfile模块文件名乱码问题

在zipfile.ZipFile中获得的filename有中日文则很大可能是乱码,这是因为

在zip标准中,对文件名的 encoding 用的不是 unicode,而可能是各种软件根据系统的默认字符集来采用(此为猜测),而zipfile中根据文件 flag 检测的时候,只支持 cp437 和 utf-8。
具体zipfile模块中的源代码如下
if flags & 0x800:
    # UTF-8 file names extension
    filename = filename.decode('utf-8')
else:
    # Historical ZIP filename encoding filename = filename.decode('cp437') 

可见编码被正确识别为utf8时的情况外,都会被识别并decode为cp437编码,但如果实际是gbk等其他编码时就变为乱码了。所以解决的方法在于被decode为cp437后重新再手动转为正确的编码。

在实际过程中可以对已经先用zipfile进行解压,然后对unzip文件夹中的乱码文件直接进行重命名。具体实现过程如下:

import os


def an_garcode(dir_names):
   
"""anti garbled code"""
    os.chdir(dir_names)


    for temp_name in os.listdir('.'):
        try:
           
#使用cp437对文件名进行解码还原
            new_name = temp_name.encode('cp437')
            #win下一般使用的是gbk编码
            new_name = new_name.decode("gbk")
            #对乱码的文件名及文件夹名进行重命名
            os.rename(temp_name, new_name)
            #传回重新编码的文件名给原文件名
            temp_name = new_name
        except:
            #如果已被正确识别为utf8编码时则不需再编码
            pass


        if os.path.isdir(temp_name):
            #对子文件夹进行递归调用
            an_garcode(temp_name)
            #记得返回上级目录
            os.chdir('..')


an_garcode(os.getcwd())

在使用zipfile解压包含中文名的文件时,可能会出现乱码的情况。这是因为在zip标准中,对文件名的编码不是使用unicode,而是根据系统的默认字符集来进行编码。而zipfile模块在检测文件标志时,只支持cp437和utf-8编码,而Windows系统使用的是gbk编码。 为了解决这个问题,有两种方法可以尝试。 第一种方法是更改zipfile模块的源代码。具体方法是在Python安装目录下找到lib文件夹下的zipfile.py文件,然后将该文件的第1374行的代码修改为`filename=filename.decode(&#39;cp437&#39;)`。这样可以将文件名从cp437编码解码为unicode编码,避免了乱码问题。 第二种方法是使用第三方库来解决乱码问题,例如使用unzip库。unzip库兼容了更多的字符编码,可以正确处理包含中文名的文件。你可以使用unzip库的相关方法来解压文件,确保文件名不会出现乱码。 通过以上两种方法,你可以成功解决zipfile解压中文乱码问题,保持文件名的正确显示。解压后的目录结构应该是正确的,中文文件名也不会出现乱码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [解决PythonZipFile解压文件名中文乱码问题](https://blog.youkuaiyun.com/qq_21076851/article/details/122752196)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [zipfile解压路径中文乱码问题](https://blog.youkuaiyun.com/drjiug/article/details/129537331)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值