方法一,读取中文名进行重写
with zipfile.ZipFile(file=zip_file, mode='r') as zf:
# 解压到指定目录,首先创建一个解压目录
if os.path.exists(unzip_dir_path):
shutil.rmtree(unzip_dir_path)
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)
方法二
def unzip_file_2(save_file,unzip_dir_path):
# 打开压缩包
with zipfile.ZipFile(save_file, 'r') as zip_file:
# 获取所有文件列表
for zip_info in zip_file.infolist():
# print(type(zip_info.filename))
if zip_info.filename.encode('cp437').decode('gbk')[-1] == '/':
# 如果是文件夹就直接创建目录
zip_file.extract(zip_info, unzip_dir_path)
else:
# 如果是文件,先将文件名从gbk编码转换为utf-8编码
# print(type(zip_info.filename.encode('cp437').decode('gbk').encode('utf-8')))
zip_info.filename = zip_info.filename.encode('cp437').decode('gbk')
# 解压文件
zip_file.extract(zip_info, unzip_dir_path)