以下是一个示例代码,演示了如何按天分组,但从特定小时开始。
from datetime import datetime, timedelta
# 定义特定的小时数
start_hour = 8
# 获取当前日期和时间
now = datetime.now()
# 计算起始日期时间
start_date = now.replace(hour=start_hour, minute=0, second=0, microsecond=0)
# 计算结束日期时间
end_date = start_date + timedelta(days=1)
# 创建一个字典来存储分组结果
groups = {}
# 迭代处理每个日期
current_date = start_date
while current_date < end_date:
# 获取当前日期的日期部分
date_key = current_date.date()
# 如果日期不在字典中,则添加一个新的键值对
if date_key not in groups:
groups[date_key] = []
# 将当前日期添加到相应的分组中
groups[date_key].append(current_date)
# 增加一个小时,以进行下一次迭代
current_date += timedelta(hours=1)
# 打印分组结果
for date_key, date_list in groups.items():
print(date_key)
for date in date_list:
print(date)
print()
这段代码首先定义了一个特定的小时数作为起始小时。然后,通过使用datetime.now()
获取当前日期和时间。接下来,通过使用replace()
方法将起始小时设置为特定小时,并将分钟、秒钟和微秒设置为0,从而计算出起始日期时间。
然后,通过将起始日期时间加上一天的时间间隔,计算出结束日期时间。
接下来,创建一个字典来存储分组结果。然后,使用一个循环来迭代处理每个日期。在每次迭代中,首先获取当前日期的日期部分作为键。如果该日期不在字典中,则添加一个新的键值对。然后,将当前日期添加到相应的分组中。最后,增加一个小时,以进行下一次迭代。
最后,通过使用两层循环,打印出分组结果。外层循环迭代处理每个日期,内层循环打印出该日期下的所有时间。
请注意,这只是一个示例代码,你可以根据自己的需求进行修改和调整。