循环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