|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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,什么时候不加?
正常都需要加上合适的编码格式
因为python默认是utf8所以如果你的文件恰好是utf8则不用加,如同瞎猫碰上个死耗子
|
|