前言
DateTime类型可以支持2种时间格式 RFC 822 和 ISO 8601,如果需要输出自己想要的格式,需要自定义日期类型。
日期格式
DateTime类型可以支持2种时间格式 RFC 822 和 ISO 8601
demo_model = api.model('DemoModel', {
# ......
'create_time': fields.DateTime(readOnly=True, dt_format='iso8601'),
'update_time': fields.DateTime(readOnly=True, dt_format='rfc822'),
})
序列化后输出的日期显示
"create_time": "2022-09-22T12:05:05",
"update_time": "Thu, 22 Sep 2022 12:05:05 -0000"
我们想要的日期类型2022-09-22 12:05:05
自定义日期类
自定义一个字段,继承fields.DateTime
class CustomDate(fields.DateTime):
'''
自定义CustomDate,原有的fileds.DateTime序列化后
只支持 rfc822,ios8601 格式,新增 strftime 格式
strftime格式下支持 format 参数,默认为 '%Y-%m-%d %H:%M:%S'
'''
def __init__(self, dt_format='rfc822', format=None, **kwargs):
super().__init__(**kwargs)
self.dt_format = dt_format
def format(self, value):
if self.dt_format in ('rfc822', 'iso8601'):
return super().format(value)
elif self.dt_format == 'str_time':
if isinstance(value, str):
return value
return value.strftime('%Y-%m-%d %H:%M:%S')
else:
raise Exception('Unsupported date format %s' % self.dt_format)
于是我们只需要设置参数dt_format='str_time'
,就可以输出自己定义的格式了。
demo_model = api.model('DemoModel', {
'create_time': CustomDate(readOnly=True, dt_format='str_time'),
'update_time': CustomDate(readOnly=True, dt_format='str_time'),
})
于是使用marshal_with就可以序列化成
"create_time": "2022-09-22 12:05:05",
"update_time": "2022-09-22 12:05:05"
标签:RESTX,自定义,format,Flask,05,DateTime,time,格式,dt
From: https://www.cnblogs.com/yoyoketang/p/16719668.html