在 Python 中确定日期是否是美国银行假日的最简单方法是什么?似乎有各种日历和网络服务列出了各个国家/地区的假期,但我没有找到任何特定于美国银行的信息
6 回答
Pandas包为此提供了一个方便的解决方案:
from pandas.tseries.holiday import USFederalHolidayCalendar
cal = USFederalHolidayCalendar()
holidays = cal.holidays(start='2014-01-01', end='2014-12-31').to_pydatetime()
if datetime.datetime(2014,01,01) in holidays:
print True
在 python 中使用假期库。
点安装假期
美国假期:
1.检查日期假期与否。
from datetime import date
import holidays
# Select country
us_holidays = holidays.US()
# If it is a holidays then it returns True else False
print('01-01-2018' in us_holidays)
print('02-01-2018' in us_holidays)
# What holidays is it?
print(us_holidays.get('01-01-2018'))
print(us_holidays.get('02-01-2018'))
2.列出美国的所有假期:
from datetime import date
import holidays
# Select country
us_holidays = holidays.US()
# Print all the holidays in US in year 2018
for ptr in holidays.US(years = 2018).items():
print(ptr)
您可以在我的博客上列出的国家/地区列表中找到您喜欢的任何国家/地区的假期。 我的假期博客
一些一般性评论:
我不认为@ast4 真的意味着“第 n 个月算法的第 n 周的第 n 天”。“第 n 个月中的第 n 周”的概念令人难以置信(如“ISO 日历”)。我从未见过用“第 n 周”定义的假期。马丁路德金纪念日是“每月第 N 个工作日”类型假期的一个例子:
MONDAY, ...., SATURDAY = range(7)
JAN, ....., DEC = range(1, 12)
Holiday("Martin L King's Birthday", type='floating',
ordinal=3, weekday=MON, month=JAN)
Holiday("Memorial Day", type='floating',
ordinal=-1, weekday=MON, month=MAY)
美国没有与复活节有关的假期。定义不难:
Holiday("Good Friday", type='moveable',
base='gregorian_easter', delta_days=-2)
Holiday("Easter Monday", etc, delta_days=1)
# Some states in Australia used to have Easter Tuesday (no kidding)
Holiday("Easter Tuesday", etc, delta_days=2)
“基准”的想法可用于迎合农历新年,实际上是任何偏离基准日期的假期,需要一个特殊的程序来计算它。
当“固定”日期是周六或周日时,所谓的“静态”假期并不固定,甚至可能消失(没有替代的休息日):
# Americans will get a day off on Friday 31 Dec 2010
# because 1 Jan 2011 is a Saturday.
Holiday("New Year's Day", type='fixed',
day=1, month=JAN, sat_adj=-1, sun_adj=????)
# Australia observes ANZAC Day on the day, with no day off
# if the fixed date falls on a weekend.
Holiday("ANZAC Day", type='fixed', day=25, month=APR, sat_adj=0, sun_adj=0)
# Two consecutive "fixed" holidays is OK; three would need re-thinking.
# Australia again:
Holiday("Christmas Day", type='fixed', day=25, month=DEC, sat_adj=2, sun_adj=1)
Holiday("Boxing Day", type='fixed', day=26, month=DEC, sat_adj=2, sun_adj=2)
我确信有一些方法可以指定上述规则不满足的假期……欢迎任何此类消息。
实际上,我最近一直在解决一个与此类似的问题。静态假期生成起来相当简单(例如新年前夜 - 12 月 31 日,(循环数年))。那里有定义明确的算法来生成浮动假期。本质上,您有一个开始日期(例如 1900 年 1 月 1 日)并从那里开始工作。我最终实现的是第 n 个月算法第 n 周的第 n 天(例如 MLK 日 = 1 月的第 3 个星期一)。复活节有点不同,但同样有明确定义的算法已经存在(耶稣受难日在你有一月之后是微不足道的)。
有一本相当不错的书,你可能想看看:日历计算
我应该提醒贡献者不要认为这一切都可以通过算法解决。三个例子:
- 大多数伊斯兰节日是农历。月球是可预测的,一些国家这样做,但其他国家明确要求新月在该国实际看到。有些人甚至把人派到高山的山顶,受命试图发现新月。如果晚上多云,可能看不到新月,所以第二天不是假期。
- 中国的一个委员会每年 11 月左右开会,决定来年 2 月中国大陆的农历新年假期的数量。更复杂的是,由于农历新年有很多公共假期,中国政府有时会指定假期后的周末为工作日,以促进经济活动。
- 由于吉祥的宗教原因,印度的证券交易所有时在周末的交易时间很短。
出于这个原因,有些公司通过 API 进行这项研究、获取更新和发布假期,但需要付费。用户通常会每天查询该 API,以防宣布新的假期。