在调用一个库时,出现了一个异常报错类似如UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128),只要该库返回结果包含中文,该结果时就会出现该异常。
原因:
Python2默认使用ASCII编码,ASCII编码不包含中文,处理中文时会报错
Python3更换为默认使用Unicode编码
解决方法(任选其一):
1.
在文件首部添加
# coding=utf-8
2.
在python的Lib\site-packages文件夹下新建一个sitecustomize.py,内容为:
# encoding=utf8import sysreload(sys)sys.setdefaultencoding('utf8')
编码
- ascii 1个字节
- gb-2312(1980)
- gbk(1995) 对gb-2312扩展,包含中日韩等国家文字
- unicode(万国码)
ucs2 固定的2个字节表示二进制和文字的对应关系 2^16
ucs4 固定的4个字节表示二进制和文字的对应关系 2^32 ->浪费空间,流量
- utf-8 对unicode进行压缩,用尽可能少的字节表示数据
开发时尽量使用utf-8进行编码,一个中文占3个字节
来源地址:https://blog.csdn.net/weixin_45627369/article/details/129735317