从数据库中查询出的日期格式是: Fri 12 Jul 2019 00:00:00 GMT
需要转换成: 2019-07-12
d= 'Fri 12 Jul 2019 00:00:00 GMT'
GMT_FORMAT = '%a %d %b %Y %H:%M:%S GMT'
date1 = datetime.datetime.strptime(d, GMT_FORMAT)
print(date1)
输出:
2019-07-12 00:00:00
上述代码中, GMT_FORMAT 的格式参考如下:
%y 两位数的年份表示(00-99)
%Y 四位数的年份表示(000-9999)
%m 月份(01-12)
%d 月内中的一天(0-31)
%H 24小时制小时数(0-23)
%I 12小时制小时数(01-12)
%M 分钟数(00=59)
%S 秒(00-59)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天(001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数(00-53)星期天为星期的开始
%w 星期(0-6),星期天为星期的开始
%W 一年中的星期数(00-53)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身
以下是具体的转换方式, 正好形成一个闭环, 也就是说 任何类型的日期都可以拿到:
将 datetime 类型转换为 str 类型:
datetime.datetime.strftime(date1, '%Y-%m-%d')
将 str 类型转换为 date 类型:
datetime.date(*map(int, d.split('-')))
从 date 类型 到 str 类型:
str(d)
将str 类型转换为 datetime 类型:
datetime.datetime.strptime(d, '%Y-%m-%d')