[Python]sqldb取数据datetime.datetime is not JSON serializable 报错问题解决

1、问题描述
使用python自带的json,将数据转换为json数据时,datetime格式的数据报错:

datetimeTypeError: datetime.datetime(2017, 3, 21, 2, 11, 21) is not JSON serializable。

2、解决方法
就是重写构造json类,遇到日期特殊处理,其余的用内置的就行。

import json  
import datetime  
  
class DateEncoder(json.JSONEncoder):  
    def default(self, obj):  
        if isinstance(obj, datetime.datetime):  
            return obj.strftime('%Y-%m-%d %H:%M:%S')  
        elif isinstance(obj, date):  
            return obj.strftime("%Y-%m-%d")  
        else:  
            return json.JSONEncoder.default(self, obj) 

使用时,调用上面定义的函数即可,如下:

print json.dumps(self_data, cls=DateEncoder)  

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容