python时间范围_在Python中获取日期时间范围之间的小时数

So I'm trying to print the total hours in intervals between a start date and an end date in python as follows:

@app.route('/test/')

def test():

date_format = "%Y-%m-%d %H:%M:%S"

start_date_time = datetime.strptime("2018-10-16 07:00:00", date_format)

end_date_time = datetime.strptime("2018-10-18 22:00:00", date_format)

def daterange(start_date_time, end_date_time):

for n in range(int ((end_date_time - start_date_time).days)):

yield start_date_time + timedelta(n)

for single_date in daterange(start_date_time, end_date_time):

def get_delta(start_date_time, end_date_time):

delta = end_date_time - start_date_time

return delta

# Split time in hours

delta = get_delta(start_date_time,end_date_time)

for i in range(delta.days * 24 + 1): # THIS IS ONLY CALCULATING 24HRS FROM TIME GIVEN START TIME NOT TILL THE SELECTED END TIME SO I'M ONLY GETTING AN EXACT 24 HOUR RANGE

currtime = start_date_time + timedelta(hours=i)

print (currtime)

return ("done")

By This i'm only managing to get the first 24 Hours from the selected date, but I wish to keep on counting and get all hours till the selected end date.

解决方案

You might be overthinking it.

from datetime import datetime, timedelta

date_format = "%Y-%m-%d %H:%M:%S"

start_date_time = datetime.strptime("2018-10-16 07:00:00", date_format)

end_date_time = datetime.strptime("2018-10-18 22:00:00", date_format)

def get_delta(l, r):

return abs(int((l-r).total_seconds())) / 3600

for h in range(int(get_delta(start_date_time, end_date_time))):

print((start_date_time + timedelta(0, h*3600)).strftime(date_format))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值