广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    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分步阅读

    在编辑器当前程序中加入如下代码,修改默认编码:

    #! /usr/bin/env python# -*- coding: utf-8 -*-

    import sysreload(sys)sys.setdefaultencoding(utf8)

    方法/步骤21/4

    在安装目录,如:python2X\Libite-packages\下,新建一个名叫sitecustomize.py文件

    2/4

    内容如下:

    import sys

    reload(sys)

    sys.setdefaultencoding(utf8)

    3/4

    重启编译器后,运行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

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-05 07:06:23  耗时:0.028
    0.0285s