• json.dumps错误:'utf8' codec can't decode byte解决方案-乾颐堂


    一次在使用json.dumps()过程中,出现错误提示:

    ERROR:"UnicodeDecodeError: 'utf8' codec can't decode byte 0xe1 in position 5: unexpected end of data"

    通过错误提示我们知道,肯定是编码问题,找到问题所在,就不难解决了。。。

    正常情况:

    1
    2
    3
    4
    5
    6
    7
    #引入json模块
    import json
    #定义一个字典
    dit = {'a':111,'b':222,'c':333}
    #把字典转换成json字符串
    #运行结果为'{"a":111,"b":222,"c":333}'
    json.dumps(dit)


    上面是正常情况,但是如果在字典中出现特殊字符,就会报上面的错

    如何解决?

    解决方案:

    我们只需要对字符串进行unicode化,忽略错误就行啦,代码如下:

    1
    unicode( value, errors='ignore')


    但是要注意,这里的value必须为字符串,这里的value就是上面的111、222、333

    然后先进行字符串unicode化,然后再使用最上面的代码进行json encode就ok了,问题就这么解决了。

    www.qytang.com/
    http://www.qytang.com/cn/list/29/
    http://www.qytang.com/cn/list/28/446.htm
    http://www.qytang.com/cn/list/28/445.htm
    http://www.qytang.com/cn/list/28/444.htm
    http://www.qytang.com/cn/list/28/442.htm
    http://www.qytang.com/cn/list/28/440.htm
    http://www.qytang.com/cn/list/28/437.htm
    http://www.qytang.com/cn/list/28/435.htm
    http://www.qytang.com/cn/list/28/434.htm
    http://www.qytang.com/cn/list/28/433.htm
    http://www.qytang.com/cn/list/28/431.htm
    http://www.qytang.com/cn/list/28/328.htm
    http://www.qytang.com/cn/list/28/326.htm
    http://www.qytang.com/cn/list/28/429.htm

  • 相关阅读:
    redis深度理解底层锁原理
    深度完整的了解MySQL锁
    今天的文章很不一般
    利用h5来进行定位当前位置
    workerman(环境+初识)
    Nginx(防止压力测试的恶意攻击)
    Java Web框架——自己动手实现一个简化版的Spring IOC框架
    设计模式——策略模式
    数据库——深入理解MySQL事务
    缓存——Redis和Memcache的对比
  • 原文地址:https://www.cnblogs.com/qytang/p/5604284.html
Copyright © 2020-2023  润新知