python UnicodeDecodeError 报错解决方法
python 2.x下字符串编码相互进行转换是件头痛的事,如中文字符串转utf-8编码存数据库,如“print '中文'.encode('utf-8')”时,如果不进行设置就会报:UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128)错误,那怎么解决呢?
操作方法
- 01
在编辑器当前程序中加入如下代码,修改默认编码: #! /usr/bin/env python# -*- coding: utf-8 -*- import sys reload(sys) sys.setdefaultencoding('utf8')
方法/步骤2
- 01
在安装目录,如:python2X\Lib\site-packages\下,新建一个名叫sitecustomize.py文件
- 02
内容如下: import sys reload(sys) sys.setdefaultencoding('utf8')
- 03
重启编译器后,运行sys.getdefaultencoding(),就会发现编码已成变成utf-8了。
- 04
出现错误分析:由于python在安装时,默认的编码是ascii。当出现非ascii字符时,就出报错。“中国”是字符串,python自动先解码将起转换为unicode,然后再encode编码为utf-8。如果不指定编码,python会自动采用默认的编码方式解码,也就是用ascii解码中文,当然出错了。 解决思路:改变默认编码为utf-8编码。
赞 (0)