#Python笔记-时间函数

不像hive里有datediff()、months_between等函数 hive 函数大全,python中似乎没找到直接的计算函数,头疼!

1.时间间隔月份数计算

def monthdiff(v_end_date,v_start_date):
    v_year_end=datetime.strptime(v_end_date, '%Y-%m-%d %H:%M:%S' ).year
    v_month_end=datetime.strptime(v_end_date, '%Y-%m-%d %H:%M:%S' ).month
    v_year_start=datetime.strptime(v_start_date, '%Y-%m-%d %H:%M:%S' ).year
    v_month_start=datetime.strptime(v_start_date, '%Y-%m-%d %H:%M:%S' ).month
    interval=(v_year_end - v_year_start)*12 + (v_month_end - v_month_start)
    return(interval)
#调用
monthdiff(str(querydate),str(reportime))  


2.时间戳转北京当地时间

import time 
time_local = time.localtime(int(timestamp)) 
report_time=int(int(data.get("reportTime"))/1000)
reportime = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(report_time))
print(reportime)


3.间隔的天数

def Caltime(date1,date2):
    #%Y-%m-%d为日期格式,其中的-可以用其他代替或者不写,但是要统一,同理后面的时分秒也一样;可以只计算日期,不计算时间。
    date1=time.strptime(date1,"%Y-%m-%d %H:%M:%S") 
    date2=time.strptime(date2,"%Y-%m-%d %H:%M:%S")
    #date1=time.strptime(date1,"%Y-%m-%d")
    #date2=time.strptime(date2,"%Y-%m-%d")
    #根据上面需要计算日期还是日期时间,来确定需要几个数组段。下标0表示年,小标1表示月,依次类推...
    date1=datetime(date1[0],date1[1],date1[2],date1[3],date1[4],date1[5])
    date2=datetime(date2[0],date2[1],date2[2],date2[3],date2[4],date2[5])
    #date1=datetime.datetime(date1[0],date1[1],date1[2])
    #date2=datetime.datetime(date2[0],date2[1],date2[2])
    #返回两个变量相差的值,就是相差天数
    #print((date2-date1).days)#将天数转成int型
    return((date2-date1).days)

print(Caltime('2019-05-13 15:03:06','2019-05-13 15:03:06') )


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值