我们讲过很多筛选的方法,不过好像并不是所有的方法都可以用来筛选时间。而且本期小编需要大家筛选的是不同时间中的相同事件,没有看清题目的小伙伴可以仔细了哦~那么,我们可以用calendar来处理吗?回答是,当然可以!接下来小编就带大家把这些时间筛选出来吧。
例如,Python 亚特兰大用户组在每个月的第二个星期四开会。要计算一年的会议日期,请使用monthcalendar()。
importcalendar importpprint pprint.pprint(calendar.monthcalendar(2017,7)) #输出 #[[0,0,0,0,0,1,2], #[3,4,5,6,7,8,9], #[10,11,12,13,14,15,16], #[17,18,19,20,21,22,23], #[24,25,26,27,28,29,30], #[31,0,0,0,0,0,0]]
0 值是与给定月份重叠的一周中的时间,是另一个月的一部分。
一周的第一天默认为星期一。可以通过调用setfirstweekday()来更改,但由于日历模块包含用于索引返回的日期范围的常量 monthcalendar(),因此在这种情况下跳过该步骤更方便。
要计算一年的小组会议日期,假设它们总是在每个月的第二个星期四,查看 monthcalendar()输出来查找星期四。本月的第一周和最后一周填充 0 值作为前一个月或后一个月天数的占位符。例如,如果一个月在星期五开始,则星期四位置第一周的值将为 0。
importcalendar
importsys
year=int(sys.argv[1])
#Showeverymonth
formonthinrange(1,13):
#Computethedatesforeachweekthatoverlapsthemonth
c=calendar.monthcalendar(year,month)
first_week=c[0]
second_week=c[1]
third_week=c[2]
#IfthereisaThursdayinthefirstweek,
#thesecondThursdayis#inthesecondweek.
#Otherwise,thesecondThursdaymustbein
#thethirdweek.
iffirst_week[calendar.THURSDAY]:
meeting_date=second_week[calendar.THURSDAY]
else:
meeting_date=third_week[calendar.THURSDAY]
print('{:>3}:{:>2}'.format(calendar.month_abbr[month],meeting_date))
#输出
#Jan:12
#Feb:9
#Mar:9
#Apr:13
#May:11
#Jun:8
#Jul:13
#Aug:10
#Sep:14
#Oct:12
#Nov:9
#Dec:14
相信试过的小伙伴已经筛选出结果了,检查一下是不是都是重复的时间呢~更多Python学习推荐:PyThon学习网教学中心。
上一篇
下一篇