在调用一个库时,出现了一个异常报错类似如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=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
编码
- ascii 1个字节
- gb-2312(1980)
- gbk(1995) 对gb-2312扩展,包含中日韩等国家文字
- unicode(万国码)
ucs2 固定的2个字节表示二进制和文字的对应关系 2^16
ucs4 固定的4个字节表示二进制和文字的对应关系 2^32 ->浪费空间,流量 文章来源:https://www.toymoban.com/news/detail-511535.html
- utf-8 对unicode进行压缩,用尽可能少的字节表示数据
开发时尽量使用utf-8进行编码,一个中文占3个字节文章来源地址https://www.toymoban.com/news/detail-511535.html
到了这里,关于解决UnicodeEncodeError: ‘ascii‘ codec can‘t encode characters in position xxx: ordinal not in range的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!