python报UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 43: ordinal not in ra...

报错信息如下:

Traceback (most recent call last):
  File "D:\Program Files\python27\lib\logging\__init__.py", line 891, in emit
    stream.write(fs % msg.encode("UTF-8"))
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 43: ordinal not in range(128)

原因:
python2在安装时,默认的编码是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
>>> sys.getdefaultencoding()
'ascii'

#解决办法
>>> import sys
>>> reload(sys)

>>> sys.setdefaultencoding('utf8')
>>> sys.getdefaultencoding()
'utf8'
>>>

上面尝试成功,网上还有一个办法没尝试
具体是在python的Lib\site-packages文件夹下新建一个sitecustomize.py,内容为:
# encoding=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')
此时重启python解释器,执行sys.getdefaultencoding(),发现编码已经被设置为utf8的了,多次重启之后,效果相同,这是因为系统在python启动的时候,自行调用该文件,设置系统的默认编码,而不需要每次都手动的加上解决代码,属于一劳永逸的解决方法。

你可能感兴趣的:(python报UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 43: ordinal not in ra...)