4

在尝试生成每个季度开始的第二个星期四的日期范围时遇到了一个奇怪的问题,从 3 月开始。

import pandas as pd
import numpy as np
from datetime import *

start = datetime(2010, 1, 1)
end = datetime(2012, 12, 31)

startrng = pd.bdate_range(start,end,freq='BQS-MAR')
startrng = startrng + pd.datetools.WeekOfMonth(week=1,weekday=3)

ts = pd.Series(np.random.randn(len(startrng)),index=startrng)

我得到以下结果:

2010-03-11   -0.585671
2010-06-10   -1.201917
2010-09-09   -0.063487
2010-12-09    0.221270
2011-03-10   -0.239836
2011-06-09    0.256052
2011-09-08    1.074758
2011-12-08    0.962388
2012-03-08   -1.601438
2012-06-14    0.854736
2012-09-13    1.532970
2012-12-13   -0.084027

虽然大多数日期偏移都有效,但 2012-06-14 实际上是本月的第三个星期四,而 2012-06-01 从星期五开始。我必须生成一个可以追溯到几年前的日期范围,手动检查所有生成的日期是没有效率的。

是否有另一种方法可以产生正确的结果集?

4

1 回答 1

1

回答:

startrng = startrng + pd.datetools.WeekOfMonth(week=1,weekday=4) - pd.datetools.BDay()
于 2012-10-09T03:40:31.237 回答