gpt4 book ai didi

python - 每月特定日期的 Pandas 日期范围

转载 作者:太空狗 更新时间:2023-10-30 02:17:36 24 4
gpt4 key购买 nike

在 Pandas 中,我知道您可以使用 anchor 偏移来指定更复杂的引用: http://pandas.pydata.org/pandas-docs/stable/timeseries.html#anchored-offset

我想指定一个日期范围,使其在每个月的第 n 天是每月的。最好的语法是什么?我正在成像与此类似的东西,它指定每 2 周在星期五重复一次:

schedule = pd.date_range(start=START_STR, periods=26, freq="2W-FRI")

最佳答案

IIUC 你可以这样做:

In [18]: pd.DataFrame(pd.date_range('2016-01-01', periods=10, freq='MS') + pd.DateOffset(days=26), columns=['Date'])
Out[18]:
Date
0 2016-01-27
1 2016-02-27
2 2016-03-27
3 2016-04-27
4 2016-05-27
5 2016-06-27
6 2016-07-27
7 2016-08-27
8 2016-09-27
9 2016-10-27

更新:考虑不同月份和闰年的天数:

def month_range(start, periods=12):
rng = pd.date_range(pd.Timestamp(start)-pd.offsets.MonthBegin(),
periods=periods,
freq='MS')
ret = (rng + pd.offsets.Day(pd.Timestamp(start).day-1)).to_series()
ret.loc[ret.dt.month > rng.month] -= pd.offsets.MonthEnd(1)
return pd.DatetimeIndex(ret)

例子:

In [202]: month_range('2016-01-27', 12)
Out[202]:
DatetimeIndex(['2016-01-27', '2016-02-27', '2016-03-27', '2016-04-27', '2016-05-27', '2016-06-27', '2016-07-27', '2016-08-27',
'2016-09-27', '2016-10-27', '2016-11-27', '2016-12-27'],
dtype='datetime64[ns]', freq=None)

In [203]: month_range('2020-01-31', 12)
Out[203]:
DatetimeIndex(['2020-01-31', '2020-02-29', '2020-03-31', '2020-04-30', '2020-05-31', '2020-06-30', '2020-07-31', '2020-08-31',
'2020-09-30', '2020-10-31', '2020-11-30', '2020-12-31'],
dtype='datetime64[ns]', freq=None)

In [204]: month_range('2019-01-29', 12)
Out[204]:
DatetimeIndex(['2019-01-29', '2019-02-28', '2019-03-29', '2019-04-29', '2019-05-29', '2019-06-29', '2019-07-29', '2019-08-29',
'2019-09-29', '2019-10-29', '2019-11-29', '2019-12-29'],
dtype='datetime64[ns]', freq=None)

关于python - 每月特定日期的 Pandas 日期范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40032371/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com