原理
在Python内部字符串的表示是unicode编码,所以通常将其作为中间码,即先将其他编码的字符串decode成unicode,再从unicode中间码encode成另一种编码。
- 易弄混的话,只记住一句话‘encode成其他格式’,或‘decode成Python内部unicode编码’。
问题
python在安装时,默认的编码是ascii,当程序中出现非ascii编码时,python的处理常常会报这样的错UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0x?? in position 1: ordinal not in range(128),python没办法处理非ascii编码的,此时需要自己设置将python的默认编码,一般设置为utf8的编码格式。
解决
设置方法如下:
- 在程序文件中以下三句
import sys
reload(sys)
sys.setdefaultencoding('utf8')
- 修改Python本环境(推荐)
在Python的Lib\site-packages文件夹下新建一个sitecustomize.py文件,内容为:
#coding=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
参考: