Python 2/3下处理cjk编码的zip文件的方法


Posted in Python onApril 26, 2019

今天项目中遇到了中文编码的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文件的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
Python实现递归遍历文件夹并删除文件
Apr 18 Python
python开发环境PyScripter中文乱码问题解决方案
Sep 11 Python
Python实现读写sqlite3数据库并将统计数据写入Excel的方法示例
Aug 07 Python
Windows系统下多版本pip的共存问题详解
Oct 10 Python
Python数据结构之哈夫曼树定义与使用方法示例
Apr 22 Python
Python实现的读取/更改/写入xml文件操作示例
Aug 30 Python
python3实现表白神器
Apr 09 Python
Python匿名函数/排序函数/过滤函数/映射函数/递归/二分法
Jun 05 Python
对python特殊函数 __call__()的使用详解
Jul 02 Python
Django实现文件上传下载
Oct 06 Python
Python + Requests + Unittest接口自动化测试实例分析
Dec 12 Python
django 外键创建注意事项说明
May 20 Python
实例详解Matlab 与 Python 的区别
Apr 26 #Python
Python生成MD5值的两种方法实例分析
Apr 26 #Python
十个Python练手的实战项目,学会这些Python就基本没问题了(推荐)
Apr 26 #Python
Python生成rsa密钥对操作示例
Apr 26 #Python
python利用Opencv实现人脸识别功能
Apr 25 #Python
Python OpenCV利用笔记本摄像头实现人脸检测
Aug 20 #Python
python使用KNN算法识别手写数字
Apr 25 #Python
You might like
php下通过curl抓取yahoo boss 搜索结果的实现代码
2011/06/10 PHP
php学习笔记 面向对象的构造与析构方法
2011/06/13 PHP
PHP获取MySql新增记录ID值的3种方法
2014/06/24 PHP
Yii模型操作之criteria查找数据库的方法
2016/07/15 PHP
理解JavaScript的caller,callee,call,apply
2009/04/28 Javascript
javascript 程序库的比较(一)之DOM功能
2010/04/07 Javascript
基于jQuery的计算文本框字数的代码
2012/06/06 Javascript
js实现幻灯片播放图片示例代码
2013/11/07 Javascript
js获取下拉列表的值和元素个数示例
2014/05/07 Javascript
JavaScript DOM节点操作方法总结
2016/08/23 Javascript
jQuery弹出div层过2秒自动消失
2016/11/29 Javascript
JQuery实现定时刷新功能代码
2017/05/09 jQuery
JavaScript的级联函数用法简单示例【链式调用】
2019/03/26 Javascript
微信小程序云开发实现增删改查功能
2019/05/17 Javascript
原生js实现商品筛选功能
2019/10/28 Javascript
跟老齐学Python之总结参数的传递
2014/10/10 Python
Python实现自动发送邮件功能
2021/03/02 Python
Python异常对代码运行性能的影响实例解析
2018/02/08 Python
python3+PyQt5自定义视图详解
2018/04/24 Python
PyCharm+PySpark远程调试的环境配置的方法
2018/11/29 Python
python原类、类的创建过程与方法详解
2019/07/19 Python
在win64上使用bypy进行百度网盘文件上传功能
2020/01/02 Python
Python浮点型(float)运算结果不正确的解决方案
2020/09/22 Python
jupyter notebook指定启动目录的方法
2021/03/02 Python
美国办公用品购物网站:Quill.com
2016/09/01 全球购物
Carter’s官方旗舰店:美国受欢迎的婴童服装品牌
2018/01/21 全球购物
阿迪达斯希腊官方网上商店:adidas希腊
2019/04/06 全球购物
某公司面试题
2012/03/05 面试题
写好自荐信的技巧
2013/11/08 职场文书
学生出入校管理制度
2014/01/16 职场文书
农村改厕实施方案
2014/03/22 职场文书
2014年科研工作总结
2014/12/03 职场文书
合作与交流自我评价
2015/03/09 职场文书
大学生入党自传2015
2015/06/26 职场文书
《穷人》教学反思
2016/02/19 职场文书
浅谈Python响应式类库RxPy
2021/06/14 Python