python UnicodeDecodeError 报错解决方法
来源:网络收集 点击: 时间:2024-04-15【导读】:
python 2.x下字符串编码相互进行转换是件头痛的事,如中文字符串转utf-8编码存数据库,如“print 中文.encode(utf-8)”时,如果不进行设置就会报:UnicodeDecodeError: ascii codec cant decode byte 0xe4 in position 0: ordinal not in range(128)错误,那怎么解决呢?工具/原料morepython方法/步骤1/1分步阅读
方法/步骤21/4
3/4
在编辑器当前程序中加入如下代码,修改默认编码:
#! /usr/bin/env python# -*- coding: utf-8 -*-
import sysreload(sys)sys.setdefaultencoding(utf8)


在安装目录,如:python2X\Libite-packages\下,新建一个名叫sitecustomize.py文件
2/4内容如下:
import sys
reload(sys)
sys.setdefaultencoding(utf8)

重启编译器后,运行sys.getdefaultencoding(),就会发现编码已成变成utf-8了。
4/4出现错误分析:由于python在安装时,默认的编码是ascii。当出现非ascii字符时,就出报错。“中国”是字符串,python自动先解码将起转换为unicode,然后再encode编码为utf-8。如果不指定编码,python会自动采用默认的编码方式解码,也就是用ascii解码中文,当然出错了。
解决思路:改变默认编码为utf-8编码。
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、文章链接:http://www.1haoku.cn/art_514233.html
上一篇:淘宝已付订金的产品不想要了订金该如何退回
下一篇:怎么在微博上开直播