UnicodeDecodeError: 'gbk' codec can't decode byte 0xa6 in position 102: illegal multibyte sequence

Python3中遇到以上错误,说明是编码方式出了错误。一般是在尝试打开以非“utf-8"编码的文件时才会出现这种错误。

比如我在windows下新建了一个名为yinyong.txt的文本文件。

我用默认的方式打开文件

with open(r"C:\Users\DongLi\Desktop\yinyong.txt") as f:
    aa=f.readlines()
print(aa)


->运行结果
<<UnicodeDecodeError: 'gbk' codec can't decode byte 0xa6 in position 102: illegal multibyte sequence

说明windows系统下TXT文件采用的是GBK编码方式,所以通过定义编码方式,python解释器就可以正确的编解码了

with open(r"C:\Users\DongLi\Desktop\yinyong.txt",mode="r",encoding="utf-8") as f:
    aa=f.readlines()
print(aa)

输出结果为:

可以看出,readlines()函数读取文件的结果是将文件的每一行加上换行符“\n”,作为列表中的一个字符串元素,源文件有多少行,则列表中就有多少个元素。

至此问题解决啦。

猜你喜欢

转载自blog.csdn.net/Muyan_Donny/article/details/81235170