循环sleep:
这是一种最简单的方式,在循环里放入要执行的任务,然后sleep一段时间再执行。缺点是,不容易控制,而且sleep是个阻塞函数。
1
2
3
4
5
6
7
8
|
def timer(n):
'''''
每n秒执行一次
'''
while True :
print time.strftime( '%Y-%m-%d %X' ,time.localtime())
yourTask() # 此处为要执行的任务
time.sleep(n)
|
threading的Timer:
threading模块中的Timer能够帮助实现定时任务,而且是非阻塞的。
比如3秒后打印helloworld:
1
2
3
4
|
def printHello():
print "hello world"
Timer( 3 , printHello).start()
|
比如每3秒打印一次helloworld:
1
2
3
4
5
6
7
8
|
def printHello():
print "Hello World"
t = Timer( 2 , printHello)
t.start()
if __name__ = = "__main__" :
printHello()
|
使用sched模块:
sched是一种调度(延时处理机制)。
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
|
# -*- coding:utf-8 -*-
# use sched to timing
import time
import os
import sched
# 初始化sched模块的scheduler类
# 第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞。
schedule = sched.scheduler(time.time, time.sleep)
# 被周期性调度触发的函数
def execute_command(cmd, inc):
'''''
终端上显示当前计算机的连接情况
'''
os.system(cmd)
schedule.enter(inc, 0 , execute_command, (cmd, inc))
def main(cmd, inc = 60 ):
# enter四个参数分别为:间隔事件、优先级(用于同时间到达的两个事件同时执行时定序)、被调用触发的函数,
# 给该触发函数的参数(tuple形式)
schedule.enter( 0 , 0 , execute_command, (cmd, inc))
schedule.run()
# 每60秒查看下网络连接情况
if __name__ = = '__main__' :
main( "netstat -an" , 60 )
|
使用定时框架APScheduler:
APScheduler是基于Quartz的一个Python定时任务框架。提供了基于日期、固定时间间隔以及crontab类型的任务,并且可以持久化任务。
这个现在还没自己尝试过,等过段时间用了再来补充。
使用windows的定时任务:
这里可以将所需要的Python程序打包成exe文件,然后在windows下设置定时执行。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/whiterbear/article/details/50232637