• 【Python】“UnicodeDecodeError: 'ascii' codec can't decode byte 0xe9”根因及解决方法


    背景

    自动化测试调用HTMLTestRunner生成测试报告的时候,出现了编码错误,错误如题

    原因

    搜索了很多资料,得出的结论是python的str默认是ascii编码,和unicode编码冲突,就会报这个错误

    解决方法

    网上的资料推荐在代码中加上如下几句可以解决这个问题:

    1 import sys
    2 reload(sys)
    3 sys.setdefaultencoding('utf8')

    深入

    博主在后来又遇到过多次编码错误,最常遇到的就是下面这个:

    “UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128)“

    后来学习了unicode和utf-8相关的内容,慢慢的对这一块有了一定的认识:

    unicode指的是万国码 是一种"字码表" 而utf-8是这种字码表储存的编码方法,编成bytecode储存,unicode还可以编码utf-16,utf-7等其他方式 

    Python中字符串类型分为两种型态:byte string、unicode string Python脚本顶部设定了“ #coding=utf-8”后所有带有中文的都会被宣告为utf-8的byte string,但是,在函数中所产生的字符串,又会是unicode string。其实两者都能表示中文,但是不代表能够混用,混用就会出错

    例如:

    response.out.write("你好"+request.get("argu"))

    中文字符“你好”会被宣告为byte string,而request.get()的结果是unicode string

    Python会自动常识吧前面的“你好”转为unicode

    但是预设的解码器是ascii,所以转换不出来,就报了上面的错误。

    一劳永逸的方法

    综上所述,一劳永逸的解决的方法有3种

    全部转为byte string  (response.out.write("你好"+request.get("argu").encode('utf-8')))

    全部转为unicode string (response.out.write(u"你好"+request.get("argu")))

    更改设定预设解码器为utf-8

    P.S.资料库存入和读取以及request拿到的参数预设就都是unicode string,若是要把byte string转unicode string可以这样转unicode(unicodestring,"utf-8")

    这样就再也不会有"UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128)"的问题产生了 遇到喷出这种错误几乎都可以用这2种方法解决

    我个人是觉得用第一种全都转byte string比较好

    因为一但用了unicode string 以后有中文字串前面都要挂个u 看起来不是很直觉 而且容易漏掉

    不如在遇到函式有中文结果(或是资料库捞出来的结果)直接都encode成utf-8就好 

    文中可能存在描述不正确,欢迎园子里的大神们指正补充!
    感谢您的阅读,如果觉得对您有帮助,就在右下角点个赞吧,感谢!

    合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。

  • 相关阅读:
    使用 ESP8266 制作 WiFi 干扰器
    苹果手机连接Wifi认证机制
    TK2 USB修复
    WiFi其他方法和WiFi事件响
    获取与esp8266连接的客户端的Mac地址 IP 端口 控制停止等问题
    WiFi其他方法和WiFi事件响应
    Arduino内部网页代理,网页穿透,公网访问Arduino内部网页
    ESP8266远程OTA升级
    分级基金及套利策略:申购套利、赎回套利、低折套利
    maven安装
  • 原文地址:https://www.cnblogs.com/Detector/p/6937397.html
Copyright © 2020-2023  润新知