python datetime.datetime is not JSON serializable 报错问题解决

来源:互联网 发布:掌上电力显示网络异常 编辑:程序博客网 时间:2024/04/28 18:38

1、问题描述

使用python自带的json,将数据转换为json数据时,datetime格式的数据报错:datetimeTypeError: datetime.datetime(2017, 3, 21, 2, 11, 21) is not JSON serializable。

2、解决方法

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

  1. import json  
  2. import datetime  
  3.   
  4. class DateEncoder(json.JSONEncoder):  
  5.     def default(self, obj):  
  6.         if isinstance(obj, datetime.datetime):  
  7.             return obj.strftime('%Y-%m-%d %H:%M:%S')  
  8.         elif isinstance(obj, date):  
  9.             return obj.strftime("%Y-%m-%d")  
  10.         else:  
  11.             return json.JSONEncoder.default(self, obj) 

使用时,调用上面定义的函数即可,如下:
  1. print json.dumps(self_data, cls=DateEncoder)  

1 0