不像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') )