Python 2/3下处理cjk编码的zip文件的方法
作者:Robert's Blog 时间:2022-08-05 17:53:40
今天项目中遇到了中文编码的zip文件,处理了蛮长时间,所以记录下,以免下次踩坑。
Python2下
Python2中读取zip文件,zipfile.ZipInfo的filename类型是str,基本上类似于python3中的bytes,即可以被decode为unicode。
所以,要处理中文,只需要将文件名按照编码decode成unicode就好。
import zipfile
fpath = '/path/to/zip.zip'
zfile = zipfile.ZipFile(fpath, 'r')
for fileinfo in zfile.filelist:
print fileinfo.filename.decode('gb18030')
# 如果要更加详细的区分bytes/str/unicode的语义
print bytes(fileinfo.filename).decode('gb18030')
Python3下
Python3中,Language encoding flag (EFS)如果是1,则按照utf8来处理文件编码,EFS如果为0,则直接按照cp437解码文件名。这是标准直接规定的。
但是,很多软件在制作zip压缩包的时候,直接使用gb18030或者其他非标准编码格式来编码文件名,所以我们还得将文件名反转为bytes,然后再使用对应的编码方式解码:
fpath = '/path/to/zip.zip'
zfile = zipfile.ZipFile(fpath, 'r')
for fileinfo in zfile.filelist:
print(fileinfo.filename.encode('cp437').decode('gb18030'))
方法都有了,那直接根据文件名智能猜测文件编码,然后解压就好。但是由于单个文件名太短,chardet的猜测可能不准,所以我们可以直接将所有的文件名连接起来,猜测编码。
代码请参考 mczip ,兼容python2和python3。
总结
以上所述是小编给大家介绍的Python 2/3下处理cjk编码的zip文件的方法,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
来源:https://www.robberphex.com/2019/04/1022
标签:python,cjk,编码,zip
0
投稿
猜你喜欢
php函数之子字符串替换 str_replace
2023-11-23 17:32:29
python使用webdriver爬取微信公众号
2022-10-06 02:13:30
Python实现串口通信(pyserial)过程解析
2021-10-11 01:49:14
Python使用matplotlib绘制多个图形单独显示的方法示例
2022-02-13 09:45:44
Python使用poplib模块和smtplib模块收发电子邮件的教程
2023-11-02 14:58:34
Python+Kepler.gl实现时间轮播地图过程解析
2021-03-27 00:20:52
本地计算机无法启动Apache故障处理
2023-07-17 13:06:48
Python configparser模块操作代码实例
2021-11-05 18:48:08
教你快速掌握数据库查询优化的实用技巧
2008-11-28 15:10:00
指定区域的图片自动按比例缩小的js代码(防止页面被图片撑破)
2024-04-17 10:05:21
php正则表达匹配中文问题分析小结
2024-04-10 10:57:03
PHP实现多文件上传的方法
2023-11-23 03:42:04
js表单检测数字
2007-10-12 13:52:00
python实现微信自动回复机器人功能
2023-12-30 01:01:40
Python加密模块的hashlib,hmac模块使用解析
2022-12-10 10:18:57
javascript实现依次输入input自动定焦
2024-04-28 10:19:12
OpenCV半小时掌握基本操作之对象测量
2023-06-08 12:09:18
Oracle数据库部分迁至闪存存储的实现方法
2024-01-26 11:22:31
javascript中可能用得到的全部的排序算法
2024-04-29 13:45:34
Python Pandas数据处理高频操作详解
2021-05-21 22:29:00