import zipfiledef unzip_file(zip_file_path, output_folder_path): with zipfile.ZipFile(zip_file_path, 'r') as zip_ref: zip_ref.extractall(output_folder_path)# 利用示例zip_file_path = 'example.zip'output_folder_path = 'output_folder'unzip_file(zip_file_path, output_folder_path)

以上代码解压的中文文件名是乱码,怎么办理?

二、实现过程

这里【瑜亮老师】给了个思路如下:乱码是什么样子的?最好能传上来一个压缩包,我们好试验。

过了几分钟,【瑜亮老师】补充道:@fashjon 我查看了一下zipfile的源码,创造是利用了'cp437'编码了文件名才导致的文件名缺点。
既然知道了缺点的编码,那么方法就很大略了,1修正源码,2自己写代码读取解压缩路径中的文件名,重新利用'cp437'编码然后用gbk解码,重命名文件名,问题办理。
修正后的代码如下:

phprename中文乱码Python代码解压的中文文件名是乱码怎么解决 AJAX

import zipfileimport osdef unzip_file(zip_file_path, output_folder_path, encoding='gbk'): with zipfile.ZipFile(zip_file_path, 'r') as zip_ref: zip_ref.extractall(output_folder_path) # 遍历解压后的目录,检讨并改动文件名 for root, dirs, files in os.walk(output_folder_path): for bad_name in files: # 假设这里我们知道ZIP文件利用的是'gbk'编码(但实际情形可能不同) if not bad_name.isascii(): # 如果文件名包含非ASCII字符 true_name = bad_name.encode('cp437').decode(encoding) os.rename(os.path.join(root, bad_name), os.path.join(root, true_name))# 利用示例zip_file_path = 'example.zip'output_folder_path = 'output_folder'unzip_file(zip_file_path, output_folder_path)

不愿定你的电脑里是否安装pathlib,因此利用了os,顺利地办理了粉丝的疑问。

粉丝追问:解压文件用什么库比较好?

回答1:这方面我只知道zipfile和代码调用winrar。
平时很少打仗匹量处理压缩包。

回答2:批量处理压缩包,直接wps批量解压就可以了;

回答3:何须wps,只要电脑上装的有任意解压软件,全选压缩包,右键,可以解压到一个文件夹,也可以每个压缩包单独天生一个文件夹。
代码只不过方便遍历多层文件夹目录,如果都在一个文件夹中,还不如右键点选更方便。

如果你也有类似这种Python干系的小问题,欢迎随时来互换群学习互换哦,有问必答!

三、总结

大家好,我是Python进阶者。
这篇文章紧张盘点了一个Python自动化办公的问题,文中针对该问题,给出了详细的解析和代码实现,帮助粉丝顺利办理了问题。

末了感谢粉丝【fashjon】提出的问题,感谢【瑜亮老师】给出的思路,感谢【莫生气】等人参与学习互换。

【提问补充】温馨提示,大家在群里提问的时候。
可以把稳下面几点:如果涉及到大文件数据,可以数据脱敏后,发点demo数据来(小文件的意思),然后贴点代码(可以复制的那种),记得发报错截图(截全)。
代码不多的话,直接发代码笔墨即可,代码超过50行这样的话,发个.py文件就行。