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

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

相关推荐
许长安1 天前
C++ 多态详解:从静态多态到动态多态
开发语言·c++·经验分享·笔记
小糖学代码1 天前
LLM系列:1.python入门:2.数值型对象
人工智能·python·ai
猫猫的小茶馆1 天前
【ARM】ARM的介绍
c语言·开发语言·arm开发·stm32·单片机·嵌入式硬件·物联网
蓑衣夜行1 天前
Qt QWebEngine 开启硬件加速注意事项
开发语言·c++·qt·web·qwebengine
CoderYanger1 天前
动态规划算法-简单多状态dp问题:15.买卖股票的最佳时机含冷冻期
开发语言·算法·leetcode·动态规划·1024程序员节
零日失眠者1 天前
这5个Python库一旦掌握就离不开
后端·python
韩曙亮1 天前
【Web APIs】JavaScript 执行机制 ( 单线程特点 | 同步任务与异步任务 | 同步先行、异步排队 | 事件循环机制 )
开发语言·前端·javascript·异步任务·同步任务·web apis·js 引擎
用户8356290780511 天前
如何使用 Python 从 Word 文档中批量提取表格数据
后端·python
洲星河ZXH1 天前
Java,比较器
java·开发语言·算法
Jerryhut1 天前
sklearn函数总结四——归一化和标准化
人工智能·python·机器学习·jupyter·sklearn