我有一个带有日期的数据框,如下表所示。第一个块是它应该是什么样子,第二个块是我在添加 BDays 时得到的。这是完成后应该是什么样子的示例。我想使用第一列并在日期上增加 5 个工作日,但如果 5 个 Bdays 与假期重叠(如 21 年 2 月 15 日),那么我需要再增加一天。使用 添加 5Bday 相当简单 pandas.tseries.offsets import BDay
,但我不能在使用数据框时跳过假期。
我曾尝试使用pandas.tseries.holiday import USFederalHolidayCalendar
workdays 和 workalendar 模块,但无法弄清楚。任何人都知道我能做什么。
正确的例子
日期 | 退出日期 +5 |
---|---|
2021/02/09 | 2021/02/17 |
2021/02/10 | 2021/02/18 |
错误的例子
日期 | 退出日期 +5 |
---|---|
2021/02/09 | 2021/02/16 |
2021/02/10 | 2021/02/17 |
以下是我尝试过的一些代码示例:
import pandas as pd
from workdays import workday
...
df['DATE'] = workday(df['EXIT DATE +5'], days=5, holidays=holidays)
下一个例子:
import pandas as pd
from pandas.tseries.holiday import USFederalHolidayCalendar
bday_us = pd.offsets.CustomBusinessDay(calendar=USFederalHolidayCalendar())
dt = df['DATE']
df['EXIT DATE +5'] = dt + bday_us
==========================================
最终代码:
下面是我最终确定的代码。由于纽约证券交易所实际交易的日子,我不得不手动定义假期。例如,布什总统安息的那一天。
import datetime as dt
import pandas as pd
from pandas.tseries.holiday import USFederalHolidayCalendar
from pandas.tseries.offsets import BDay
from pandas.tseries.holiday import AbstractHolidayCalendar, Holiday, nearest_workday, \
USMartinLutherKingJr, USPresidentsDay, GoodFriday, USMemorialDay, \
USLaborDay, USThanksgivingDay
class USTradingCalendar(AbstractHolidayCalendar):
rules = [
Holiday('NewYearsDay', month=1, day=1, observance=nearest_workday),
USMartinLutherKingJr,
USPresidentsDay,
GoodFriday,
USMemorialDay,
Holiday('USIndependenceDay', month=7, day=4, observance=nearest_workday),
Holiday('BushDay', year=2018, month=12, day=5),
USLaborDay,
USThanksgivingDay,
Holiday('Christmas', month=12, day=25, observance=nearest_workday)
]
offset = 5
df = pd.DataFrame(['2019-10-11', '2019-10-14', '2017-04-13', '2018-11-28', '2021-07-02'], columns=['DATE'])
df['DATE'] = pd.to_datetime(df['DATE'])
def offset_date(start, offset):
return start + pd.offsets.CustomBusinessDay(n=offset, calendar=USTradingCalendar())
df['END'] = df.apply(lambda x: offset_date(x['DATE'], offset), axis=1)
print(df)