翼度科技»论坛 编程开发 python 查看内容

Python实现定时任务的多种方式

8

主题

8

帖子

24

积分

新手上路

Rank: 1

积分
24
一、循环sleep:

最简单的方式,在循环里放入要执行的任务,然后sleep一段时间再执行。缺点是,不容易控制,而且sleep是个阻塞函数
  1. def timer(n):  
  2.     '''''
  3.     每n秒执行一次
  4.     '''  
  5.     while True:   
  6.         print(time.strftime('%Y-%m-%d %X',time.localtime()))   
  7.         yourTask()  # 此处为要执行的任务   
  8.         time.sleep(n)
复制代码
二、threading的Timer:

例如:5秒后执行
  1. def printHello():  
  2.     print("start" )
  3.   
  4. Timer(5, printHello).start()  
复制代码
例如:间隔5秒执行一次
  1. def printHello():  
  2.     print("start" )
  3.     timer = threading.Timer(5,printHello)
  4.     timer.start()
  5.   
  6. if __name__ == "__main__":  
  7.     printHello()
复制代码
例如:两种方式组合用,5秒钟后执行,并且之后间隔5秒执行一次
  1. def printHello():  
  2.     print("start")  
  3.     timer = threading.Timer(5,printHello)
  4.     timer.start()
  5.   
  6. if __name__ == "__main__":  
  7.     timer = threading.Timer(5,printHello)
  8.     timer.start()
复制代码
三、sched模块:

sched是一种调度(延时处理机制)。
  1. import time  
  2. import os  
  3. import sched  
  4.   
  5.   
  6. # 初始化sched模块的scheduler类  
  7. # 第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞。  
  8. schedule = sched.scheduler(time.time, time.sleep)  
  9.   
  10. # 被周期性调度触发的函数  
  11. def execute_command(cmd, inc):  
  12.     print('执行主程序')
  13.    
  14.     '''''
  15.     终端上显示当前计算机的连接情况
  16.     '''  
  17.     os.system(cmd)  
  18.     schedule.enter(inc, 0, execute_command, (cmd, inc))  
  19.   
  20.   
  21. def main(cmd, inc=60):  
  22.     # enter四个参数分别为:间隔事件、优先级(用于同时间到达的两个事件同时执行时定序)、被调用触发的函数,  
  23.     # 给该触发函数的参数(tuple形式)  
  24.     schedule.enter(0, 0, execute_command, (cmd, inc))  
  25.     schedule.run()  
  26.   
  27.   
  28. # 每60秒查看下网络连接情况  
  29. if __name__ == '__main__':  
  30.     main("netstat -an", 60)
复制代码
四、定时框架APScheduler:

APScheduler是基于Quartz的一个Python定时任务框架。提供了基于日期、固定时间间隔以及crontab类型的任务,并且可以持久化任务。
需要先安装apscheduler库,cmd窗口命令:pip install apscheduler
简单的间隔时间调度代码:
  1. from datetime import datetime
  2. import time
  3. import os
  4. from apscheduler.schedulers.background import BackgroundScheduler
  5. #学习中遇到问题没人解答?小编创建了一个Python学习交流群:531509025
  6. def tick():
  7.     print('Tick! The time is: %s' % datetime.now())
  8. if __name__ == '__main__':
  9.     scheduler = BackgroundScheduler()
  10.     # 间隔3秒钟执行一次
  11.     scheduler.add_job(tick, 'interval', seconds=3)
  12.     # 这里的调度任务是独立的一个线程
  13.     scheduler.start()
  14.     print('Press Ctrl+{0} to exit'.format('Break' if os.name == 'nt' else 'C'))
  15.     try:
  16.         # 其他任务是独立的线程执行
  17.         while True:
  18.             time.sleep(2)
  19.             print('sleep!')
  20.     except (KeyboardInterrupt, SystemExit):
  21.         scheduler.shutdown()
  22.         print('Exit The Job!')
复制代码
五、定时框架Celery:

非常强大的分布式任务调度框架;
需要先安装Celery库,cmd窗口命令: pip install Celery
六、定时框架RQ:

基于Redis的作业队列工具,优先选择APScheduler定时框架;
七、使用windows的定时任务:

可以将所需要的Python程序打包成exe文件,然后在windows下设置定时执行。
八、Linux的定时任务(Crontab):

在Linux下可以很方便的借助Crontab来设置和运行定时任务。进入Crontab文件编辑页面,设置时间间隔,使用一些shell命令来运行bash脚本或者是Python脚本,保存后Linux会自动按照设定的时间来定时运行程序。

来源:https://www.cnblogs.com/Pythonmiss/p/18360964
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具