前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python定时任务实现方式

Python定时任务实现方式

作者头像
菲宇
发布2019-06-13 15:16:09
2.1K0
发布2019-06-13 15:16:09
举报
文章被收录于专栏:菲宇

Python下实现定时任务的方式有很多种方式。

一、循环sleep:

 最简单的方式,在循环里放入要执行的任务,然后sleep一段时间再执行。缺点是,不容易控制,而且sleep是个阻塞函数

代码语言:javascript
复制
def timer(n):  
    ''''' 
    每n秒执行一次 
    '''  
    while True:    
        print(time.strftime('%Y-%m-%d %X',time.localtime()))    
        yourTask()  # 此处为要执行的任务    
        time.sleep(n)   

二、threading的Timer:

 例如:5秒后执行

代码语言:javascript
复制
def printHello():  
    print("start" )
  
Timer(5, printHello).start()  

 例如:间隔5秒执行一次

代码语言:javascript
复制
def printHello():  
    print("start" )
    timer = threading.Timer(5,printHello)
    timer.start()
  
if __name__ == "__main__":  
    printHello()  

例如:两种方式组合用,5秒钟后执行,并且之后间隔5秒执行一次

代码语言:javascript
复制
def printHello():  
    print("start")  
    timer = threading.Timer(5,printHello)
    timer.start()
  
if __name__ == "__main__":  
    timer = threading.Timer(5,printHello)
    timer.start()

三、sched模块:

 sched是一种调度(延时处理机制)。

代码语言:javascript
复制
import time  
import os  
import sched   
  
# 初始化sched模块的scheduler类  
# 第一个参数是一个可以返回时间戳的函数,第二个参数可以在定时未到达之前阻塞。  
schedule = sched.scheduler(time.time, time.sleep)   
# 被周期性调度触发的函数  
def execute_command(cmd, inc):  
    print('执行主程序')
    
    ''''' 
    终端上显示当前计算机的连接情况 
    '''  
    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类型的任务,并且可以持久化任务。

 需要先安装apscheduler库,cmd窗口命令:pip install apscheduler

 简单的间隔时间调度代码:

代码语言:javascript
复制
from datetime import datetime
import time
import os
from apscheduler.schedulers.background import BackgroundScheduler

def tick():
    print('Tick! The time is: %s' % datetime.now())

if __name__ == '__main__':
    scheduler = BackgroundScheduler()
    # 间隔3秒钟执行一次
    scheduler.add_job(tick, 'interval', seconds=3)
    # 这里的调度任务是独立的一个线程
    scheduler.start()
    print('Press Ctrl+{0} to exit'.format('Break' if os.name == 'nt' else 'C'))
    try:
        # 其他任务是独立的线程执行
        while True:
            time.sleep(2)
            print('sleep!')
    except (KeyboardInterrupt, SystemExit):
        scheduler.shutdown()
        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会自动按照设定的时间来定时运行程序。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019年05月24日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、循环sleep:
  • 二、threading的Timer:
  • 三、sched模块:
  • 四、定时框架APScheduler:
  • 五、定时框架Celery:
  • 六、定时框架RQ:
  • 七、使用windows的定时任务:
  • 八、Linux的定时任务(Crontab):
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档