鱼C论坛

 找回密码
 立即注册
查看: 2146|回复: 3

[已解决]文件 求助

[复制链接]
发表于 2020-3-15 20:42:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
>>> f = open('C:\\Users\\83489\\Desktop\\新建文本文档.txt')
>>> f.read()
Traceback (most recent call last):
  File "<pyshell#1>", line 1, in <module>
    f.read()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xad in position 40: illegal multibyte sequence

修改后
>>> f = open('C:\\Users\\83489\\Desktop\\新建文本文档.txt',encoding = 'utf8')
>>> f.seek(5)
5
>>> f.readline()
Traceback (most recent call last):
  File "<pyshell#10>", line 1, in <module>
    f.readline()
  File "C:\Users\83489\AppData\Local\Programs\Python\Python38\lib\codecs.py", line 322, in decode
    (result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbd in position 0: invalid start byte

可以read,但是readline报错

想知道为什么?
最佳答案
2020-3-15 21:08:44
本帖最后由 sunrise085 于 2020-3-15 21:20 编辑

这个错误是说utf-8编码格式下,不能seek(5),会导致出错。
原因是utf-8编码格式下,每个汉字占位3字节,你使用f.seek(5)后,光标不在正常的汉字开始处,读取出错了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-15 21:08:44 | 显示全部楼层    本楼为最佳答案   
本帖最后由 sunrise085 于 2020-3-15 21:20 编辑

这个错误是说utf-8编码格式下,不能seek(5),会导致出错。
原因是utf-8编码格式下,每个汉字占位3字节,你使用f.seek(5)后,光标不在正常的汉字开始处,读取出错了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-15 21:16:21 | 显示全部楼层
sunrise085 发表于 2020-3-15 21:08
这个错误是说utf-8编码格式下,不能seek(5),会导致出错。
原因是utf-8编码格式下,每个汉字占位4字节,你 ...

噢噢噢噢!!!原来如此!!谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-15 21:20:47 | 显示全部楼层
塞利格曼的狗 发表于 2020-3-15 21:16
噢噢噢噢!!!原来如此!!谢谢

不好意思刚刚写错了。utf-8编码,汉字站位3个字节。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-3-14 21:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表