numpy.busdaycalendar#
- class numpy.busdaycalendar(weekmask='1111100', holidays=None)[source]#
一个业务日历对象,高效地存储定义 busday 系列函数有效日期的信息。
默认有效日期为星期一至星期五(“工作日”)。busdaycalendar 对象可以用任何一组每周有效日来指定,加上可选的始终无效的“节假日”日期。
创建 busdaycalendar 对象后,weekmask 和 holidays 就无法修改。
- 参数:
- weekmaskstr 或 array_like of bool,可选
一个七元素数组,指示星期一到星期日中的哪些是有效日。可以指定为长度为七的列表或数组,例如 [1,1,1,1,1,0,0];长度为七的字符串,例如 '1111100';或者像“Mon Tue Wed Thu Fri”这样的字符串,由工作日的三个字符缩写组成,可选用空格分隔。有效的缩写为:Mon Tue Wed Thu Fri Sat Sun
- holidaysarray_like of datetime64[D],可选
一个日期数组,无论它们落在哪个星期几,都将被视为无效日期。节假日日期可以按任何顺序指定,而 NaT(非时间)日期将被忽略。此列表以适合快速计算有效日的标准化形式保存。
- 返回值:
- outbusdaycalendar
包含指定的 weekmask 和 holidays 值的业务日历对象。
参见
is_busday
返回一个布尔数组,指示有效日期。
busday_offset
应用以有效日计数的偏移量。
busday_count
计算半开日期范围内有多少个有效日。
备注
创建 busdaycalendar 对象后,无法修改 weekmask 或 holidays。属性返回内部数据的副本。
示例
>>> import numpy as np >>> # Some important days in July ... bdd = np.busdaycalendar( ... holidays=['2011-07-01', '2011-07-04', '2011-07-17']) >>> # Default is Monday to Friday weekdays ... bdd.weekmask array([ True, True, True, True, True, False, False]) >>> # Any holidays already on the weekend are removed ... bdd.holidays array(['2011-07-01', '2011-07-04'], dtype='datetime64[D]')