解决Python复杂zip文件的解压问题
废话不多说,直接看问题,使用过 Python
中的标准库 zipfile
解压过 zip
格式压缩包的朋友们,可能遇到过,当压缩文件中的目录或文件名中包含中文等常见 unicode
字符时,典型如下面的例子:
使用 zipfile
的 extract()
或 extractall()
方法直接解压时,产生的解压结果名充斥着乱码,这一点我们通过调用 namelist()
方法就可以看出来:
from zipfile import ZipFile # 读入压缩包文件 file = ZipFile('示例压缩包.zip') # 查看压缩包内目录、文件名称 file.namelist()
这是因为 zipfile
中针对压缩包内容的编码兼容性差,但我们可以通过下面的函数自行矫正:
def recode(raw: str) -> str: ''' 编码修正 ''' try: return raw.encode('cp437').decode('gbk') except: return raw.encode('utf-8').decode('utf-8') for file_or_path in file.namelist(): print(file_or_path, ' -------> ' , recode(file_or_path))
解决了文件名乱码的问题后,接下来我们就可以配合 shutil
与 os
标准库中的相关功能,实现将指定任意 zip
压缩包,完好地解压到指定的目录中,代码如下:
def zip_extract_all(src_zip_file: ZipFile, target_path: str) -> None: # 遍历压缩包内所有内容 for file_or_path in file.namelist(): # 若当前节点是文件夹 if file_or_path.endswith('/'): try: # 基于当前文件夹节点创建多层文件夹 os.makedirs(os.path.join(target_path, recode(file_or_path))) except FileExistsError: # 若已存在则跳过创建过程 pass # 否则视作文件进行写出 else: # 利用shutil.copyfileobj,从压缩包io流中提取目标文件内容写出到目标路径 with open(os.path.join(target_path, recode(file_or_path)), 'wb') as z: # 这里基于Zipfile.open()提取文件内容时需要使用原始的乱码文件名 shutil.copyfileobj(src_zip_file.open(file_or_path), z) # 向已存在的指定文件夹完整解压当前读入的zip文件 zip_extract_all(file, '解压测试')
可以看到,效果完美 :
到此这篇关于Python复杂zip文件的解压的文章就介绍到这了,更多相关Python zip文件的解压内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Python文件读取read() readline() readlines()函数使用场景技巧示例
这篇文章主要介绍了Python文件读取read() readline()及readlines()函数使用场景技巧示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-08-08Pandas.DataFrame删除指定行和列(drop)的实现
本文主要介绍了Pandas.DataFrame删除指定行和列(drop)的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-02-02vscode中配置jupyter的详细步骤(彻底解决Failed to start the Kernel问题)
自从vscode出了支持jupyter notebook的功能之后,我就再也没有傻傻的用浏览器开过jupyter(问就是vscode好看),下面这篇文章主要给大家介绍了关于vscode中配置jupyter(彻底解决Failed to start the Kernel问题)的相关资料,需要的朋友可以参考下2022-12-12tensorflow dataset.shuffle、dataset.batch、dataset.repeat顺序区别详
这篇文章主要介绍了tensorflow dataset.shuffle、dataset.batch、dataset.repeat顺序区别详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2020-06-06python pymysql链接数据库查询结果转为Dataframe实例
这篇文章主要介绍了python pymysql链接数据库查询结果转为Dataframe实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-06-06
最新评论