python 任意时间段内的工作日计算(剔除法定节假日和周末)

本文介绍了如何使用python计算任意时间段内排除法定节假日和周末的工作日数量,通过自定义假期和补班日期列表实现,强调了日期格式要求及法定假期更新的重要性。
摘要由CSDN通过智能技术生成

之前找到一个python的包,可以计算一个自然月内的工作日共几天。
但是不能计算任意时间段内的工作日共有几天,经过查找资料,总算找到了一种方法。
所以便记录下来,有需要的小伙伴可以自行拿去用。
代码如下:

import pandas as pd
from pandas.tseries.offsets import CustomBusinessDay
def count_weekday(s_day, e_day):
     holidays_list= CustomBusinessDay(holidays=['2021-0
Python计算工作日排除法定节假日)的方法主要包括以下几个步骤: 1. 首先,我们需要先获取法定节假日的列表,可以通过网络查询或者其他途径获取。法定节假日通常是固定的,例如元旦、春节、劳动节等。 2. 根据获取的法定节假日列表,我们可以创建一个包含所有节假日日期的集合。 3. 接下来,我们需要引入datetime模块来进行日期的计算。这个模块提供了处理日期和时间的相关函数和类。 4. 首先,我们可以定义一个函数来计算两个日期之间的天数差。可以使用datetime模块中的date类的substract方法来实现。 5. 然后,我们可以定义一个函数来计算两个日期之间的工作日数量。首先计算两个日期之间的天数差,然后减去周末的天数和法定节假日的天数即可。 6. 最后,我们可以将上述两个函数结合起来,计算出指定日期范围内的工作日数量。 下面是一个示例代码,用于计算2022年3月1日至2022年4月30日之间的工作日数量(排除法定节假日): ```python import datetime public_holidays = [ # 根据实际情况添加法定节假日的日期 datetime.date(2022, 4, 4), # 清明节 datetime.date(2022, 5, 1) # 劳动节 ] def get_working_days(start_date, end_date): days = (end_date - start_date).days + 1 working_days = days for i in range(days): date = start_date + datetime.timedelta(days=i) if date.weekday() >= 5 or date in public_holidays: working_days -= 1 return working_days start_date = datetime.date(2022, 3, 1) end_date = datetime.date(2022, 4, 30) working_days = get_working_days(start_date, end_date) print(f"工作日数量:{working_days}") ``` 上述代码中,我们首先定义了一个public_holidays列表,其中包含了2022年的清明节和劳动节日期。然后,我们通过get_working_days函数计算了2022年3月1日至2022年4月30日之间的工作日数量,并将结果打印输出。 这样,我们就可以用Python计算工作日排除法定节假日)了。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值