鱼C论坛

 找回密码
 立即注册
查看: 1701|回复: 1

[已解决]新手关于文件的疑问

[复制链接]
发表于 2020-3-15 21:00:18 | 显示全部楼层 |阅读模式
1鱼币
>>> 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:00:19
这个错误是说utf-8编码格式下,不能seek(5),会导致出错。
原因是utf-8编码格式下,每个汉字占位3字节,你使用f.seek(5)后,光标不在正常的汉字开始处,读取出错了。


注意,以后请不要重复发帖

最佳答案

查看完整内容

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

使用道具 举报

发表于 2020-3-15 21:00:19 | 显示全部楼层    本楼为最佳答案   
这个错误是说utf-8编码格式下,不能seek(5),会导致出错。
原因是utf-8编码格式下,每个汉字占位3字节,你使用f.seek(5)后,光标不在正常的汉字开始处,读取出错了。


注意,以后请不要重复发帖
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

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

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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