鱼C论坛

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

[已解决]打开txt文件,什么时候需要utf-8,什么时候不用?

[复制链接]
发表于 2020-12-23 16:35:20 | 显示全部楼层 |阅读模式

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

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

x

首先,打开鱼c课本第八章,视频28讲record.txt
>>> f = open('record.txt')
>>> f.read()
顺利读出来
'小客服:小甲鱼,今天有客户问你有没有女朋友?\n小甲鱼:咦??\n小客服:我跟她说你有女朋友了!\n小甲鱼:。。。。。。\n小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"\n小甲鱼:然后呢?\n小客服:她买了两个,说发一个货就好~\n小甲鱼:呃。。。。。。你真牛!\n小客服:那是,谁让我是鱼C最可爱小客服嘛~\n小甲鱼:下次有人想调戏你我不阻止~\n小客服:滚!!!\n================================================================================\n
......后面太长不贴了

自己建一个record3.txt  内容如下:
小客服:小甲鱼,有个好评好好学哈(为分隔方便,冒号是英文冒号)
=====================
小甲鱼:哦?
小甲鱼:“左手拿着小甲鱼,右手拿着打火机,哪里不会点哪里!
>>> f = open('record3.txt')
>>> f.read()
这里报错了!
Traceback (most recent call last):
  File "<pyshell#261>", line 1, in <module>
    f.read()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 4: illegal multibyte sequence

自己网上查了查,需要open时加上encoding='utf-8',于是这个record3.txt也顺利读出来了:
>>> f = open('record3.txt', encoding = 'utf-8')
>>> f.read()
'小客服:小甲鱼,有个好评好好学哈\n=====================\n小甲鱼:哦?\n小甲鱼:“左手拿着小甲鱼,右手拿着打火机,哪里不会点哪里!\n=====================\n小客服:“有了小甲鱼,以后妈妈再也不用担心我的学习了。”\n=====================\n小甲鱼:哈哈哈,我看到了,我还发微博了呢。\n=====================\n小客服:嗯嗯,我看到你的微博了。\n=====================\n小甲鱼:“左手拿着小甲鱼,右手拿着打火机,哪里不会点哪里!”'
问题来了:回到record.txt,加上encoding='utf-8'反而读不出来了:
>>> f = open('record.txt', encoding = 'utf-8')
>>> f.read()
Traceback (most recent call last):
  File "<pyshell#271>", line 1, in <module>
    f.read()
  File "C:\ProgramData\Anaconda3\pkgs\python-3.8.5-h5fd99cc_1\lib\codecs.py", line 322, in decode
    (result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbf in position 2: invalid start byte

为什么? record.txt和record3.txt都是中文句子,有什么区别?什么时候参数加utf-8,什么时候不加?
最佳答案
2020-12-23 18:20:42
正常都需要加上合适的编码格式
因为python默认是utf8所以如果你的文件恰好是utf8则不用加,如同瞎猫碰上个死耗子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-23 18:20:42 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
正常都需要加上合适的编码格式
因为python默认是utf8所以如果你的文件恰好是utf8则不用加,如同瞎猫碰上个死耗子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-10 16:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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