python time 和 datetime 模块——处理时间信息

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秒

posted on 2018-03-29 22:45  海盗Ora  阅读(599)  评论(0编辑  收藏  举报

导航