答案 0 :(得分:134)
我花了很多时间也想在01:00启动一个简单的Python程序。出于某种原因,我无法启动 cron ,并且APScheduler看起来相当复杂,应该很简单。时间表(https://pypi.python.org/pypi/schedule)似乎是正确的。
您必须安装他们的Python库:
pip install schedule
这是从他们的示例程序中修改的:
import schedule
import time
def job(t):
print "I'm working...", t
return
schedule.every().day.at("01:00").do(job,'It is 01:00')
while True:
schedule.run_pending()
time.sleep(60) # wait one minute
您需要将自己的功能放在工作位置并使用nohup运行,例如:
nohup python2.7 MyScheduledProgram.py &
如果重新启动,请不要忘记重新启动它。
答案 1 :(得分:46)
你可以这样做:
from datetime import datetime
from threading import Timer
x=datetime.today()
y=x.replace(day=x.day+1, hour=1, minute=0, second=0, microsecond=0)
delta_t=y-x
secs=delta_t.seconds+1
def hello_world():
print "hello world"
#...
t = Timer(secs, hello_world)
t.start()
这将在第二天凌晨1点执行一个函数(例如hello_world)。
修改强>
正如@PaulMag所建议的那样,更为一般的是,为了检测是否必须在月末到达时重置该月的日期,在此上下文中y的定义应如下:
y = x.replace(day=x.day, hour=1, minute=0, second=0, microsecond=0) + timedelta(days=1)
通过此修复,还需要将timedelta添加到导入中。其他代码行保持不变。因此,使用total_seconds()函数的完整解决方案是:
from datetime import datetime, timedelta
from threading import Timer
x=datetime.today()
y = x.replace(day=x.day, hour=1, minute=0, second=0, microsecond=0) + timedelta(days=1)
delta_t=y-x
secs=delta_t.total_seconds()
def hello_world():
print "hello world"
#...
t = Timer(secs, hello_world)
t.start()
答案 2 :(得分:13)
APScheduler可能就是您的追求。
from datetime import date
from apscheduler.scheduler import Scheduler
# Start the scheduler
sched = Scheduler()
sched.start()
# Define the function that is to be executed
def my_job(text):
print text
# The job will be executed on November 6th, 2009
exec_date = date(2009, 11, 6)
# Store the job in a variable in case we want to cancel it
job = sched.add_date_job(my_job, exec_date, ['text'])
# The job will be executed on November 6th, 2009 at 16:30:05
job = sched.add_date_job(my_job, datetime(2009, 11, 6, 16, 30, 5), ['text'])
https://apscheduler.readthedocs.io/en/latest/
您可以通过将其构建到您正在安排的功能中来安排另一次运行。
答案 3 :(得分:7)
我需要类似的任务。这是我写的代码: 它计算第二天并将时间更改为所需的时间,并查找currentTime和下一个计划时间之间的秒数。
import datetime as dt
def my_job():
print "hello world"
nextDay = dt.datetime.now() + dt.timedelta(days=1)
dateString = nextDay.strftime('%d-%m-%Y') + " 01-00-00"
newDate = nextDay.strptime(dateString,'%d-%m-%Y %H-%M-%S')
delay = (newDate - dt.datetime.now()).total_seconds()
Timer(delay,my_job,()).start()