Python报错 “UnicodeDecodeError: ‘gb2312’ codec can’t decode byte 0xa4 in position… : illegal multibyte

一、报错场景

使用python遇到报错:“UnicodeDecodeError: ‘gb2312’ codec can’t decode byte 0xa4 in position… : illegal multibyte sequence”一般有如下两种场景:

1.爬取中文网站内容

html = requests.get(url).decode("gb2312")

2.读取gbk编码的文件

result = open(filename, 'r', encoding='gb2312')

二、报错原因

gb2312收录的中文字符集不够全面,在遇到如繁体字的时候会出现解码错误。

汉字字符集范围 gb2312 < gbk < gb18030

三、报错解决

1.忽略解码错误

html = requests.get(url).decode('gb2312',errors = 'ignore')

decode函数默认的参数就是strict,decode([encoding], [errors='strict']),可以用第二个参数控制错误处理的策略,strict表示遇到非法字符时抛出异常;
如果设置为ignore,则会忽略非法字符;
如果设置为replace,则会用?取代非法字符;

2.将gbk2312替换为中文字符集更全面的gbk

result = open(filename, 'r', encoding='gbk')

 

注:如果采用'ignore'忽略非法字符报错,读出来的中文将是乱码,如果想要读取准确中文内容可以先将gb2312编码的内容转为utf-8再进行读取。

res = requests.get(url)
res = unicode(res, "gb2312").encode("utf8")
res.encoding = 'utf-8'
html = res.text
print(html)

此时可以正常输出中文字符了。

 

上一篇:leetcode344&345之反转字符串中的元音字母


下一篇:【python-爬虫】中文乱码