python 对数据json序列化失败的常见问题解析!

用python flask框架在linux开发数据接口的时候,从mysql数据库执行sql获取的数据,通过json.dumps()方法转化会报错,经常会碰到以下两种提示:

TypeError: Object of type 'decimal' is not json serializable jsonify!

TypeError: Object of type 'datetime' is not JSON serializable

这是因为你的数据中包含了datetimeDecimal类型的数据,这两种类型是不能直接进行不能直接进行JSON序列化的!!

查看源码我们可以看到json.dumps()方法中有一个cls的参数,默认为None,

此时,我们再进入SONEncoder这个类,发现这就是Python数据序列化为JSON格式的数据时数据类型的对应关系:

 其中并不包含datetimeDecimal两种类型,这个时候如果我们想处理这种数据,就要重新改写这个类,需要先把这两种类型的数据转化为str,然后再进行格式话操作。:

# 记得导入所需的模块
import datetime
import  decimal


# 继承原有的JSONEncoder类
class DecEncoder(json.JSONEncoder):
    def default(self, obj):
        if isinstance(obj, decimal.Decimal):
            return float(obj)
        if isinstance(obj, datetime.datetime):
            return obj.strftime('%Y-%m-%d %H:%M:%S')
        if isinstance(obj, datetime.date):
            return obj.strftime("%Y-%m-%d")

        super(DecEncoder, self).default(o)

 然后,后面使用json.dumps()方法的时候,我们可以加上cls参数:

from datetime import datetime

aa = datetime.now()

dd = json.dumps(aa,cls=DecEncoder)

 

 好了,这样 就不会报错了!收工~~~

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值