Python执行定时任务
python使用内置库和第三方库执行定时任务。
使用 sched 模块
sched相当于一个延时处理任务
schedule是简单明了的一个第三方定时任务库,需要先pip安装一下
一个很好的例子
import schedule
import time
# 定义你要周期运行的函数
def job():
print("I'm working...")
schedule.every(10).minutes.do(job) # 每隔 10 分钟运行一次 job 函数
schedule.every().hour.do(job) # 每隔 1 小时运行一次 job 函数
schedule.every().day.at("10:30").do(job) # 每天在 10:30 时间点运行 job 函数
schedule.every().monday.do(job) # 每周一 运行一次 job 函数
schedule.every().wednesday.at("13:15").do(job) # 每周三 13:15 时间点运行 job 函数
schedule.every().minute.at(":17").do(job) # 每分钟的 17 秒时间点运行 job 函数
while True:
schedule.run_pending() # 运行所有可以运行的任务
time.sleep(1)
传递参数
import schedule
import time
# 定义你要周期运行的函数
def job(msg):
print("I'm working...")
print('接受参数为:{}'.format(msg))
schedule.every(10).seconds.do(job,msg='10s')
while True:
schedule.run_pending() # 运行所有可以运行的任务
time.sleep(1)
执行并发任务
import schedule,time
def job1(msg):
time.sleep(1)
print('任务1接受参数为:{}'.format(msg))
def job2(msg):
time.sleep(2)
print('任务2接受参数为:{}'.format(msg))
def job3(msg):
time.sleep(3)
print('任务3接受参数为:{}'.format(msg))
schedule.every(1).seconds.do(job1,msg='任务1')
schedule.every(3).seconds.do(job2,msg='任务2')
schedule.every(1).seconds.do(job3,msg='任务3')
while 1:
schedule.run_pending()
实际上应该是顺序执行
加入使用threading完成并发
# -*- coding:utf-8 -*-
import schedule,time
import threading
def job1(msg):
time.sleep(1)
print('任务1接受参数为:{}'.format(msg))
def job2(msg):
time.sleep(2)
print('任务2接受参数为:{}'.format(msg))
def job3(msg):
time.sleep(3)
print('任务3接受参数为:{}'.format(msg))
def ensure_schedule_1():
threading.Thread(target=job1,args=(1,)).start()
def ensure_schedule_2():
threading.Thread(target=job2,args=(2,)).start()
def ensure_schedule_3():
threading.Thread(target=job3,args=(3,)).start()
def run():
schedule.every(1).seconds.do(ensure_schedule_1)
schedule.every(1).seconds.do(ensure_schedule_2)
schedule.every(1).seconds.do(ensure_schedule_3)
while 1:
schedule.run_pending()
run()