应聘网站运营建设面试,网站制作 青岛,合肥网站建设方案书,开发公司项目管理部门获奖主持词乱码得原因#xff1a;
由于ZipFile模块导出遇到中文解码不对#xff0c;windows上会出现#xff0c;linux是否会出现不知道没测试过。
解决方式#xff1a;
1. 搞个文件名引射表(不太方便#xff0c;少量文件夹套用时候还可以)
2. 修改源码解码格式(不太方便#xff0c;…乱码得原因
由于ZipFile模块导出遇到中文解码不对windows上会出现linux是否会出现不知道没测试过。
解决方式
1. 搞个文件名引射表(不太方便少量文件夹套用时候还可以)
2. 修改源码解码格式(不太方便自己搞了一下之后报其他错误)
3. 自己写入文件自己创建文件夹(推荐)
自己创建的写法
with zipfile.ZipFile(filezip_save_path, moder) as zf:
# 解压到指定目录,首先创建一个解压目录
os.mkdir(unzip_dir_path)
for old_name in zf.namelist():
# 获取文件大小目的是区分文件夹还是文件如果是空文件应该不好用。
file_size zf.getinfo(old_name).file_size
# 由于源码遇到中文是cp437方式所以解码成gbkwindows即可正常
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(filenew_path, modewb) as f:
# zf.read 是读取压缩包里的文件内容
f.write(zf.read(old_name))
else:
# 是文件夹就创建
os.mkdir(new_path)
结果正常以上就是python解压zip包中文乱码解决方法的详细内容更多关于python 解压zip包中文乱码的资料请关注脚本之家其它相关文章