我试图做一些类似于this的事情,但是我想用实际的工作日名称和时间来指定开始日期和结束日期。例如,我想检查当前的日期时间(datetime.datetime.now())是否在周二下午4:30和星期四上午11:45之间这将是每周更新,所以它必须是星期二/星期四的心态。
我已经考虑过如何在平日里工作(但我不知道如何将时间部分融入其中):
TimeNow = datetime.datetime.now()
if TimeNow.weekday() >= 1 and TimeNow.weekday() <= 3:
#runcodehere对我怎么做有什么想法吗?
发布于 2015-08-19 15:10:33
最简洁的方法是使用一周内经过的分钟数:
def mins_in_week(day, hour, minute):
return day * 24 * 60 + hour * 60 + minute
if (mins_in_week(1, 16, 30) <
mins_in_week(TimeNow.weekday(), TimeNow.hour, TimeNow.minute) <
mins_in_week(3, 11, 45)):
....发布于 2015-08-19 15:08:56
它并不是很整洁,但像这样的东西应该能工作:
TimeNow = datetime.datetime.now()
if (TimeNow.weekday() == 1 and ((TimeNow.hour() == 4 and TimeNow.minute >= 30) or TimeNow.hour > 4)) or (TimeNow.weekday() == 2) or (TimeNow.weekday() == 3 and (TimeNow.hour() < 11 or (TimeNow.hour() == 11 and TimeNow.minute <= 45)):
#runcodehere发布于 2015-08-19 15:12:47
您可以使用and和or的组合,并且每天都有不同的条件:
import datetime
TimeNow = datetime.datetime.now()
day_now = TimeNow.weekday()
time_now = TimeNow.hour*60 + TimeNow.minute
if (day_now == 1 and time_now > 990) or (day_now == 2) or (day_now == 3 and time_now < 705):
# do somethinghttps://stackoverflow.com/questions/32098954
复制相似问题