在列表中创建开始和结束日期元组



我对python很陌生,所以我需要一些帮助。下面的代码完成了任务,但我觉得这不是最有效的方法,任何输入都将不胜感激。

目标:1(传递字符串开始和结束日期2(创建一个列表,以便能够将请求分块到API。每个结束日期需要在开始日期之后4小时3(列表中的每个后续开始日期需要在上一个开始日期之后3小时4(当最终开始日期>=时结束列表结束日期

重要的是,最终编号必须显示为"2018-06-05T09 2018-06-05T13",否则我的API请求将不起作用

提前感谢大家!

from datetime import datetime, timedelta
import numpy as np
start='2018-06-05T00'
end='2020-11-01T23'
start_date = datetime.strptime(start, '%Y-%m-%dT%H')
end_date = datetime.strptime(end, '%Y-%m-%dT%H')
delta = timedelta(hours=3)
end_date_initial = start_date + timedelta(hours=4)
start_date_list = [start_date]
end_date_list = [end_date_initial]
while True:
start_date += delta
start_date_list.append(start_date)
if start_date >= end_date:
break
while True:
end_date_initial += delta
end_date_list.append(end_date_initial)
if end_date_initial >= end_date:
break
start_date_array = np.array(start_date_list)
end_date_array = np.array(end_date_list)
formated_start_date = []
formated_end_date = []
for i in range(len(start_date_array)):
formated_start_date.append(start_date_array[i].strftime('%Y-%m-%dT%H'))
for i in range(len(end_date_array)):
formated_end_date.append(end_date_array[i].strftime('%Y-%m-%dT%H'))
# print(start_date_array[0], end_date_array[0])
# print(formated_start_date[0], formated_end_date[0])
time = formated_start_date[0] + ' ' + formated_end_date[0]
def listOfTuples(i, j):
return list(map(lambda x, y:(x + ' ' + y), i, j))
time_tuples = listOfTuples(formated_start_date, formated_end_date)
print(time_tuples[3])

如果我理解正确,你可以很容易地做到这一点,并且仍然可以利用numpy的矢量化和广播功能:

import numpy as np

ti, tf = np.datetime64("2018-06-05T00"), np.datetime64("2020-11-01T23")
start = np.arange(ti, tf, np.timedelta64(3, "h"))
end = start + np.timedelta64(4, "h")
api_times = [" ".join(map(str, t)) for t in zip(start, end)]

相关内容

最新更新