python time 和 datetime 模块——处理时间信息
时间信息在数据挖掘中有着举足轻重的作用,比如判断当前是否工作日,节假日,工作时间下班时间等,都是从日期得到的新的时间特征;比如我们想要预测下一个小时的人体血糖值,那么我们需要决定建模长度,如果建模长度为7,那么每次建模的时我们都需要取当前时刻的前7个时刻历史数据作为模型输入,此时用到了
datetime.datetime.now() - datetime.timedelta(days=5);或者在数据库操作中,我们需要选择表中数据日期为2018-03-28的数据记录
SELECT id FROM table(表名) WHERE concat(YEAR,'-', MONTH, '-',DAY) = "2018-03-28"
格式化日期
我们可以使用 time 模块的 strftime 方法来格式化日期,:
import time # 格式化成2016-03-20 11:45:39形式 print (time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())) # 格式化成Sat Mar 28 22:24:24 2016形式 print (time.strftime("%a %b %d %H:%M:%S %Y", time.localtime())) # 将格式字符串转换为时间戳 a = "Sat Mar 28 22:24:24 2016" print (time.mktime(time.strptime(a,"%a %b %d %H:%M:%S %Y")))
以上实例输出结果:
2018-03-29 22:20:02
Thu Mar 29 22:20:02 2018
1459175064.0
得知当前是第几周,周几
print (datetime.datetime.now()) #与datetime.today显示一样,显示当前时间 now1 = datetime.datetime.now() print (now1.isocalendar()) #显示为(2017, 42, 2) 代表2017年的第42周星期2 print (now1.isoweekday()) #显示周几 print (datetime.datetime.now() - datetime.timedelta(days=5)) #显示计算日期时间差
输出结果
2018-03-29 22:27:55.985858 (2018, 13, 4) 4 2018-03-24 22:27:55.986861
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 当前时区的名称
%% %号本身
时间日期,星期,年份,月份,小时,显示
import datetime i = datetime.datetime.now() print ("当前的日期和时间是 %s" % i) print ("ISO格式的日期和时间是 %s" % i.isoformat() ) print ("当前的年份是 %s" %i.year) print ("当前的月份是 %s" %i.month) print ("当前的日期是 %s" %i.day) print ("dd/mm/yyyy 格式是 %s/%s/%s" % (i.day, i.month, i.year) ) print ("当前小时是 %s" %i.hour) print ("当前分钟是 %s" %i.minute) print ("当前秒是 %s" %i.second)
输出:
当前的日期和时间是 2018-03-29 22:34:38.206140 ISO格式的日期和时间是 2018-03-29T22:34:38.206140 当前的年份是 2018 当前的月份是 3 当前的日期是 29 dd/mm/yyyy 格式是 29/3/2018 当前小时是 22 当前分钟是 34 当前秒是 38
时间信息一行输出显示
import datetime import time now = datetime.datetime.now() #now2 = now + datetime.timedelta(days=-2) weekends = now.isoweekday() weeklists = ['星期一','星期二','星期三','星期四','星期五','星期六','星期日'] #li = enumerate(weeklists,1) for i in enumerate(weeklists,1): #print i[0],i[1] if weekends == i[0]: Today_week = i[1] times = '今天是 ' + str(time.strftime('%Y-%m-%d %H:%M:%S')) + ' ' + Today_week print (Today_week) print (times)
输出:
星期四
今天是 2018-03-29 22:36:11 星期四
计算两个时间日期之间相差的时间:
import datetime import time starttime = datetime.datetime.now() time.sleep(150) #延迟150秒 可以写自己的程序所用时间 endtime = datetime.datetime.now() #print (endtime - starttime).seconds #计算时间差 单位为秒 time_difference = (endtime - starttime).seconds #int类型 hours = time_difference / 3600 minutes = time_difference / 60 seconds = time_difference % 60 finall_time = '经过了' + str(hours) + '小时' + str(minutes) + '分钟' + str(seconds) + '秒' #int转化为str print finall_time
#输出:
经过了0.041666666666666664小时2.5分钟30秒