python解压zip包中文乱码解决方法
乱码得原因:
由于ZipFile模块导出遇到中文解码不对,windows上会出现,linux是否会出现不知道没测试过。
解决方式:
1. 搞个文件名引射表(不太方便,少量文件夹套用时候还可以)
2. 修改源码解码格式(不太方便,自己搞了一下,之后报其他错误)
3. 自己写入文件,自己创建文件夹(推荐)
自己创建的写法:
with zipfile.ZipFile(file=zip_save_path, mode=’r’) as zf: # 解压到指定目录,首先创建一个解压目录 os.mkdir(unzip_dir_path) for old_name in zf.namelist():# 获取文件大小,目的是区分文件夹还是文件,如果是空文件应该不好用。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创建文件,写入数据 with open(file=new_path, mode=’wb’) as f: # zf.read 是读取压缩包里的文件内容 f.write(zf.read(old_name))else: # 是文件夹,就创建 os.mkdir(new_path)
结果正常:
以上就是python解压zip包中文乱码解决方法的详细内容,更多关于python 解压zip包中文乱码的资料请关注好吧啦网其它相关文章!
相关文章:
1. 正则表达式匹配${key}并在Java中使用的详细方法2. python 解决pycharm运行py文件只有unittest选项的问题3. Python通过fnmatch模块实现文件名匹配4. Android Studio 4.0 正式发布在Ubuntu 20.04中安装的方法5. 解决vue scoped scss 无效的问题6. 低版本IE正常运行HTML5+CSS3网站的3种解决方案7. python+adb+monkey实现Rom稳定性测试详解8. 关于python中readlines函数的参数hint的相关知识总结9. 基于Java实现简单贪吃蛇游戏10. log4net在Asp.net MVC4中的使用过程
