python处理时间,按照周分割时间段

在实际的开发中,我们经常要设计一些工具类,对于时间来说,有时候需要将其处理成时间段。

例如,对于2024年08月01日2024年08月16日的时间段,我们如何将其处理成时间段[2024-08-01, 2024-08-03], [2024-08-04, 2024-08-10], [2024-08-11, 2024-08-16]。如下表所示:

周日 周一 周二 周三 周四 周五 周六
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16

这里,我们采用迭代就可以实现,通过计算每个阶段的开始日期和结束日期,先根据当前阶段开始日期计算当周周日的日期,再判断总的结束日期是否在周日前,如果在,则将第一段时间的结束日期确定为总的结束日期。如果在超出了周日,则将周日定为该阶段的结束日期,以此类推。

这里我们用到几个函数
datetime.datetime.strptime:将字符串转为日期对象
datetime.timedelta: 计算当前日期前推或后推后的日期。
datetime.weekday: 计算当前日期是星期几,其中0代表周末,1代表周一,2代表周二,以此类推。

python 复制代码
def split_date_range(start_date_input: str, end_date_input: str) -> list:
    # 将输入的日期字符串转换为日期对象
    start_date = datetime.datetime.strptime(start_date_input, '%Y-%m-%d')
    end_date = datetime.datetime.strptime(end_date_input, '%Y-%m-%d')
    periods = []
    current_date = start_date
    while current_date <= end_date:
        sunday = current_date + datetime.timedelta(days=(6 - current_date.weekday()))
        if sunday <= end_date:
            periods.append((current_date.strftime('%Y-%m-%d'), sunday.strftime('%Y-%m-%d')))
        else:
            periods.append((current_date.strftime('%Y-%m-%d'), end_date.strftime('%Y-%m-%d')))
            break
        # 更新当前日期为周的结束日期的下一天,以便开始下一个周期
        current_date = sunday + datetime.timedelta(days=1)
    return periods

这样我们就可以推算每一周的时间阶段了

如果我们只要工作日的时间阶段呢?应该如何修改这段程序,可以把周期的结束时间调整为周五的日期,也就是周日往前推2天。

周日 周一 周二 周三 周四 周五 周六
1 2
5 6 7 8 9
12 13 14 15 16

程序如下:

python 复制代码
def split_date_range(start_date_input: str, end_date_input: str) -> list:
    start_date = datetime.datetime.strptime(start_date_input, '%Y-%m-%d')
    end_date = datetime.datetime.strptime(end_date_input, '%Y-%m-%d')
    periods = []
    current_date = start_date
    while current_date <= end_date:
        sunday = current_date + datetime.timedelta(days=(6 - current_date.weekday()))
        friday = current_date + datetime.timedelta(days=(6 - 2 - current_date.weekday()))
        if friday <= end_date:
            periods.append((current_date.strftime('%Y-%m-%d'), friday.strftime('%Y-%m-%d')))
        else:
            periods.append((current_date.strftime('%Y-%m-%d'), end_date.strftime('%Y-%m-%d')))
            break
        current_date = sunday + datetime.timedelta(days=1)
    return periods

就会自动把周六日的时间去掉,得到的时间就变为了:

相关推荐
AAI机器之心1 分钟前
这个RAG框架绝了:无论多少跳,LLM只调用两次,成本暴降
人工智能·python·ai·llm·agent·产品经理·rag
Fairy要carry2 分钟前
项目01-手搓Agent之loop
前端·javascript·python
郝学胜-神的一滴17 分钟前
【技术实战】500G单行大文件读取难题破解!生成器+自定义函数最优方案解析
开发语言·python·程序人生·面试
愤豆21 分钟前
02-Java语言核心-语法特性-注解体系详解
java·开发语言·python
AI视觉网奇27 分钟前
vllm 踩坑记录 算力匹配
pytorch·python·深度学习
2301_8227828236 分钟前
自动化与脚本
jvm·数据库·python
是翔仔呐36 分钟前
第13章 SPI通信协议全解:底层时序、4种工作模式与W25Qxx Flash芯片读写实战
c语言·开发语言·stm32·单片机·嵌入式硬件·学习·gitee
qq_1481153738 分钟前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
2401_8785302143 分钟前
自定义内存布局控制
开发语言·c++·算法
wjs20241 小时前
SQLite 子查询
开发语言