首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算特定日历中给定工作日增量的日期?

如何计算特定日历中给定工作日增量的日期?
EN

Stack Overflow用户
提问于 2020-06-22 23:57:54
回答 1查看 72关注 0票数 0

我知道有一些方法可以计算两个日期之间的工作日差异(例如:np.busdaypy-bizdays)。

但是如何计算工作日的时间增量呢?

例如,我想要查找距离2020年6月18日(星期四)的3个工作日的日期。我想要到2020年6月23日(也就是下周二)。

目前,我有这个,但我相信它可能存在一个更好的方法来做到这一点。(注意:biz_diff只是我自己的np.busdays实现,它返回的int是两个工作日的日期之差)。

代码语言:javascript
复制
def biz_delta(from_date: datetime, delta: int) -> datetime:
    '''
    Compute delta in business days.
    '''
    approx = from_date + timedelta(days=(delta//5 * 2 + delta))
    while not (biz_diff(from_date=from_date, to_date=approx) == delta):
        approx += timedelta(days=1)
    return approx

编辑:@Balaji_Ambresh answer在大多数情况下都是令人满意的,但是当我第一次问这个问题时,我确实预料到了一个问题(不确定我是否应该为此打开一个新的线程)。

所提出的解决方案的问题是,它只将周末计算为非工作日。我还需要添加所有的节假日。我目前的方法是通过py-bizdays包在我的biz_diff函数中加载所有假日的列表。

EN

回答 1

Stack Overflow用户

发布于 2020-06-23 00:10:10

这就是了:

代码语言:javascript
复制
>>> from datetime import date
>>> from pandas.tseries.offsets import BusinessDay
>>> 
>>> start = date(2020, 6, 18)
>>> end = (start + BusinessDay(3)).date()
>>> print(end)
2020-06-23
>>> 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62518562

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档