我们经常需要定时的执行某个任务,在Linux下我们有强大的crontab,但是在Python这个粒度(定时执行函数),如何处理呢?
除了第三方的模块外,标准库为我们提供了sched模块和Timer类。
先说sched模块,准确的说,它是一个调度(延时处理机制),每次想要定时执行某任务都必须写入一个调度。
使用步骤如下:
(1)生成调度器:
s = sched.scheduler(time.time,time.sleep)
第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞。可以说sched模块设计者是“在下很大的一盘棋”,比如第一个函数可以是自定义的一个函数,不一定是时间戳,第二个也可以是阻塞socket等。
(2)加入调度事件
其实有enter、enterabs等等,我们以enter为例子。
s.enter(x1,x2,x3,x4)
四个参数分别为:间隔事件、优先级(用于同时间到达的两个事件同时执行时定序)、被调用触发的函数,给他的参数(注意:一定要以tuple给如,如果只有一个参数就(xx,))
(3)运行
s.run()
注意sched模块不是循环的,一次调度被执行后就Over了,如果想再执行,请再次enter
import time,sched
#被调度触发的函数
def event_func(msg):
print "Current Time:",time.time(),'msg:',msg
if __name__ == "__main__":
#初始化sched模块的scheduler类
s = sched.scheduler(time.time,time.sleep)
#设置两个调度
s.enter(1,2,event_func,("Small event.",))
s.enter(2,1,event_func,("Big event.",))
s.run()
while True:
time.sleep(100)
import sched
import time
scheduler = sched.scheduler(time.time, time.sleep)
def func(name):
print 'action: %s' % name , time.time()
print 'START:', time.time()
scheduler.enter(2, 1, func, ('fight',))
scheduler.enter(3, 1, func, ('make peace',))
scheduler.run()
print 'END:', time.time()
import sched
import time
scheduler = sched.scheduler(time.time, time.sleep)
def func(name):
print 'BEGIN: %s:' % name, time.time()
time.sleep(2)
print 'FINISH %s:' % name, time.time()
print 'START:', time.time()
scheduler.enter(2, 1, func, ('fight',))
scheduler.enter(3, 1, func, ('make peace',))
scheduler.run()
print 'END:', time.time()
import sched
import time
scheduler = sched.scheduler(time.time, time.sleep)
now = time.time()
def func(name):
print 'action:', time.time(), name
print 'START:', now
scheduler.enterabs(now + 2, 2, func, ('make peace',))
scheduler.enterabs(now + 2, 1, func, ('fight',))
scheduler.run()
print 'END:', now
import sched
import threading
import time
scheduler = sched.scheduler(time.time, time.sleep)
counter = 0
def increment_counter(name):
global counter
print 'action: %s' % name , time.time()
counter += 1
print 'counter: ', counter
print 'START:', time.time()
action1 = scheduler.enter(2, 1, increment_counter, ('action1',))
action2 = scheduler.enter(3, 1, increment_counter, ('action2',))
t = threading.Thread(target=scheduler.run)
t.start()
scheduler.cancel(action1)
t.join()
print 'counter:', counter
print 'END:', time.time()