在项目中遇到时间格式转换的问题,由CST形式的string转为XXXX-XX-XX形式的日期,如:
原来:Thu Jun 22 00:00:00 CST 2017
目标:2017-06-22
一番查找后,找到了解决方法,思路:利用strptime和strftime方法,先将原本格式的时间转成时间戳,再利用strftime转成规定形式的字符
函数:
import time
def cst_to_str(cstTime):
tempTime = time.strptime(cstTime,'%a %b %d %H:%M:%S CST %Y')
resTime = time.strftime('%Y-%m-%d',tempTime)
return resTime
python中时间日期格式化符号:
%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 当前时区的名称
%% %号本身
例如:
格式化成2009-03-20 11:45:39形式
time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
格式化成Sat Mar 28 22:24:24 2009形式
time.strftime("%a %b %d %H:%M:%S %Y", time.localtime())
另附calendar模块获取某个月份天数的方法
import calendar
days = calendar.monthrange(year,month)
如
days = calendar.monthrange(2018,1)
print days
>>>31