003_006 Python 自动查询节日,即计算日期之间的放假日期
2014-03-24 23:58
465 查看
代码如下:
打印结果如下:
中国
(4, [datetime.date(2014, 4, 20), datetime.date(2014, 12, 25), datetime.date(2014, 3, 23), datetime.date(2014, 9, 1)])
#encoding=utf-8 print '中国' #自动查询节日 给定起始日期和结束日期,自动获取总共的节假日天数 import datetime from dateutil import rrule,easter try: set except NameError: from sets import Set as set #复活节 def all_easter(start, end): easters = [easter.easter(y) for y in xrange(start.year,end.year+1)] return [d for d in easters if start<=d<=end] #开始到结束的节礼日列表 def all_boxing(start, end): one_day = datetime.timedelta(days=1) boxings = [easter.easter(y) + one_day for y in xrange(start.year,end.year+1)] return [d for d in boxings if start<=d<=end] #返回开始和结束日期之间的圣诞节列表 def all_christmas(start, end): christmases = [datetime.date(y,12,25) for y in xrange(start.year, end.year + 1)] return [d for d in christmases if start<=d<=end] #返回劳动节列表 def all_labor(start, end): labors = rrule.rrule(rrule.YEARLY, bymonth=9, byweekday=rrule.MO(1),dtstart=start, until=end) return [d.date() for d in labors] #读取设定的节假日 def read_holidays(start, end, holidays_file='holidays.txt'): try: holidays_file = open(holidays_file) except IOError,err: print 'open failed' return [] holidays = [] for line in holidays_file: if line.isspace() or line.startswith('#'): continue try: y,m,d = [int(x.strip()) for x in line.split(',')] date = datetime.date(y,m,d) except ValueError: print 'Invalid line find' continue if start <= date <=end: holidays.append(date) holidays_file.close() return holidays holidays_by_country = { 'US':(all_easter,all_christmas,all_labor), 'IT':(all_easter,all_boxing,all_labor) } def holidays(cc,start,end,holidays_file='holidays.txt'): all_holidays= read_holidays(start,end,holidays_file) functions = holidays_by_country.get(cc,()) for function in functions: all_holidays += function(start,end) all_holidays = list(set(all_holidays)) return (len(all_holidays),all_holidays) test_file = open(r'D:\123.txt','w') test_file.write('2014,3,23') test_file.close() print holidays('US',datetime.date(2014,1,1),datetime.date(2014,12,31),r'D:\123.txt')
打印结果如下:
中国
(4, [datetime.date(2014, 4, 20), datetime.date(2014, 12, 25), datetime.date(2014, 3, 23), datetime.date(2014, 9, 1)])
相关文章推荐
- python计算日期之间的放假日期
- 003_003 Python 计算日期之间隔了几周
- 003_005 Python 计算日期之间的工作日
- 003_007 Python 日期的模糊查询 即读取不太符合标准的日期信息
- 003_001 Python 计算昨天和明天的日期
- python写的计算两个日期之间的天数的脚本
- Python:计算两个日期之间的天数
- 在两个文本框中输入日期数据后,第三个文本框能够自动计算出两个日期之间的天数
- 这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询。这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧!
- Android 计算两个日期之间的天数并打印所有日期
- MySql查询两个时间点之间的日期列表
- 基于Python实现自动慢查询分析,邮件自动发送
- MySQL查询两个日期之间记录的方法
- C语言计算两个日期之间的天数
- java计算两个日期之间相差的天数
- java计算两个日期之间相差的天数
- 计算两个日期之间相差的天数
- 计算两个日期之间有多少个工作日的方法(同理也可以计算有多少个双休日)
- Sql计算两个日期之间的天数
- 计算两个日期之间的时间