文章详情页
python - 使用`zipfile`模块在不解压缩的情况下如何使用text模式读取文本文件?
浏览:109日期:2022-06-28 10:12:34
问题描述
我使用的Python版本为3.5.2,尝试用zipfile模块的zipfile.ZipFile.open方法打开一个压缩包中的文本文件时,即使使用了文档中要求的rU参数,打开时仍然是以二进制数据格式打开的,百思不得其解。
代码:
>>> import zipfile>>> zf = zipfile.ZipFile(’/Users/chiqingjun/Downloads/top-1m.csv.zip’)>>> zf.namelist()[’top-1m.csv’]>>> f = zf.open(zf.namelist()[0], mode=’rU’)>>> f<zipfile.ZipExtFile name=’top-1m.csv’ mode=’rU’ compress_type=deflate>>>> f.readline()b’1,google.comn’# 仍然是二进制数据
官方文档(3.5.2版本):
问题解答
回答1:其实最后输出的二进制, 和zipfile无关, 是和py3.5有关, 你可以在输出的结果解码, 就能得到字符类型了
content = f.readline()print(content.decode(’utf8’))回答2:
文档已经说了呀,rU是 通用换行符,并且将在3.6 移除此模式。
压缩文件以二进制读取字节内容是应该的,后面如何转码由程序员决定。
相关文章:
1. 在mac下出现了两个docker环境2. 看了好几遍为什么点击登录没有反应呢 在线等。。。。3. java - 在session里面设了一个对象,但是在Jsp中取不到4. javascript - Object.create(null) 和 {} 区别是什么5. javascript - webpack打包问题6. javascript - webpack-dev-server 打包没有报错 但是没有生成文件7. mysql - SQL分组排序、随机问题?8. Python pyinstaller 打包后在其他电脑运行失败9. python3.x - c++调用python310. mysql - sql 语句更改表结构,添加多个列,怎么写?
排行榜
