【python】Python中实现定时任务常见的几种方式原理分析与应用实战

news2024/11/24 15:42:18

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,PyQt5和Tkinter桌面开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生K8S,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:python综合应用,基础语法到高阶实战教学
景天的主页:景天科技苑

在这里插入图片描述

文章目录

  • Python中常见的定时任务详细用法教程
    • 1. 使用time.sleep()实现定时任务
      • 原理
      • 示例代码
      • 优缺点
    • 2. 使用threading.Timer实现定时任务
      • 原理
      • 示例代码
      • 优缺点
    • 3. 使用sched模块实现定时任务
      • 原理
      • 示例代码
      • 优缺点
    • 4. 使用schedule库实现定时任务
      • 原理
      • 示例代码(使用`schedule`库)
      • 更复杂的示例
      • 优缺点
    • 5. 使用系统级别的定时任务
      • Linux(cron)
      • Windows(Task Scheduler)
      • 优缺点
    • 6. 使用APScheduler库实现定时任务
      • 安装
      • 示例代码
      • 优缺点
    • 7. 定时任务的最佳实践
      • 1. 确保任务的原子性
      • 2. 捕获异常
      • 3. 定时任务的日志记录
      • 4. 使用持久化存储
      • 5. 考虑任务的重试机制
      • 6. 监控和警报
      • 7. 使用适当的调度器
    • 8. 总结

Python中常见的定时任务详细用法教程

在Python中,实现定时任务是一个常见的需求,无论是在自动化脚本、数据处理、系统监控还是其他许多应用场景中。Python提供了多种方法来实现定时任务,包括使用标准库、第三方库以及系统级别的工具。本文将详细介绍几种常见的Python定时任务实现方式,并结合实际案例进行说明。

1. 使用time.sleep()实现定时任务

原理

time.sleep()函数是Python中最简单直观的定时任务实现方式。它使当前线程暂停执行指定的时间(秒)。通过结合while True循环,可以创建一个简单的定时任务执行器。

示例代码

import time

def task():
    print("Task executed at", time.ctime())

def loop_monitor():
    while True:
        task()
        time.sleep(10)  # 暂停10秒

if __name__ == "__main__":
    loop_monitor()

优缺点

  • 优点:实现简单,易于理解。
  • 缺点:只能设定间隔,不能指定具体的时间(如每天上午8点执行)。同时,sleep()期间程序处于阻塞状态,无法处理其他任务。

2. 使用threading.Timer实现定时任务

原理

threading.Timerthreading模块中的一个类,它表示一个定时器,用于在指定时间后执行一个函数。与time.sleep()相比,Timer可以创建多个定时任务,且这些任务是异步执行的。

示例代码

import threading

def task():
    print("Task executed at", time.ctime())
    # 如果需要重复执行,可以重新设置Timer
    # timer = threading.Timer(10, task)
    # timer.start()

timer = threading.Timer(10, task)
timer.start()

# 注意:上述代码只执行一次,若需重复执行,需要取消注释重新设置Timer的部分

# 若想持续运行,可结合循环
def start_recurring_timer():
    def loop():
        while True:
            timer = threading.Timer(10, task)
            timer.start()
            timer.join()  # 等待当前timer执行完成,否则可能产生大量线程
    
    t = threading.Thread(target=loop)
    t.start()

# 启动重复执行的定时器
start_recurring_timer()

优缺点

  • 优点:可以实现异步执行,支持多个定时任务。
  • 缺点:每次需要重复执行时,都需要重新设置Timer,且join()方法会阻塞主线程,影响性能。

3. 使用sched模块实现定时任务

原理

sched模块提供了一个通用的事件调度器,允许你安排在特定时间执行特定任务。它支持多线程应用,可以在每个任务执行后立刻调用延时函数,确保其他线程也能执行。

示例代码

import sched
import time

def task():
    print("Task executed at", time.ctime())

def loop_monitor():
    s = sched.scheduler(time.time, time.sleep)
    s.enter(5, 1, task, ())
    s.run()

if __name__ == "__main__":
    loop_monitor()

# 注意:sched.scheduler的run()方法会阻塞直到没有更多任务
# 若要重复执行,需将任务添加和run()调用放在循环中

def start_recurring_scheduler():
    s = sched.scheduler(time.time, time.sleep)
    while True:
        s.enter(5, 1, task, ())
        s.run()

# 启动重复执行的调度器(通常不推荐这样使用,因为run()会阻塞)
# 一种更好的方法是结合threading.Thread

优缺点

  • 优点:支持多线程,可以安排多个任务。
  • 缺点run()方法会阻塞,不适合需要频繁执行的任务。

4. 使用schedule库实现定时任务

原理

schedule是一个轻量级的Python任务调度库,支持以人性化的语法按固定时间间隔执行任务。它提供了秒、分、小时、日期等多种时间单位,并且易于理解和使用。

示例代码(使用schedule库)

首先,你需要安装schedule库(如果你还没有安装的话)。可以通过pip安装:

pip install schedule

然后,你可以这样使用schedule库来安排你的定时任务:

import schedule
import time

def task():
    print("Task executed at", time.ctime())

# 安排任务:每隔10秒执行一次
schedule.every(10).seconds.do(task)

if __name__ == "__main__":
    while True:
        # 运行所有可以运行的任务
        schedule.run_pending()
        # 暂停一秒(为了减少CPU使用率,不需要每次循环都检查)
        time.sleep(1)

更复杂的示例

schedule库还支持更复杂的定时规则,比如每天、每周、每月等:

import schedule
import time

def job():
    print("I'm working...")

# 每天的10:30执行
schedule.every().day.at("10:30").do(job)

# 每周一的10:30执行
schedule.every().monday.at("10:30").do(job)

# 每月的第三个星期一的10:30执行
schedule.every().monday.do(job).tag('monthly-task')
schedule.every().third.monday.do(job, 'It is the third Monday of the month!').tag('monthly-task', 'third-monday')

# 取消带有特定标签的任务
# schedule.clear('monthly-task')

if __name__ == "__main__":
    while True:
        schedule.run_pending()
        time.sleep(1)

优缺点

  • 优点
    • 易于理解和使用,提供人性化的语法。
    • 支持多种时间单位(秒、分、小时、日期等)。
    • 支持标签功能,便于管理和取消任务。
  • 缺点
    • 对于非常精确的时间控制(如毫秒级),可能不够精确。
    • 如果主程序崩溃,定时任务也会停止。

5. 使用系统级别的定时任务

Linux(cron)

在Linux系统中,可以使用cron服务来安排定时任务。Python脚本可以通过cron来定时执行。

首先,编辑cron任务列表:

crontab -e

然后,添加一行来安排你的Python脚本(假设脚本名为my_script.py):

*/10 * * * * /usr/bin/python3 /path/to/your/script/my_script.py

这表示每10分钟执行一次my_script.py

Windows(Task Scheduler)

在Windows系统中,可以使用任务计划程序(Task Scheduler)来安排定时任务。

  1. 打开“任务计划程序”。
  2. 点击“创建基本任务…”。
  3. 遵循向导,设置触发器(何时开始任务)、操作(启动程序)等。
  4. 在“操作”步骤中,选择“启动程序”,然后浏览到你的Python脚本文件。

优缺点

  • 优点
    • 跨应用程序使用,不仅限于Python。
    • 系统级别的任务管理,更加稳定和可靠。
  • 缺点
    • 需要额外的配置,可能不如Python内置或第三方库方便。
    • 对于非系统管理员用户,可能需要管理员权限来设置任务。

当然,我们可以继续深入讨论关于Python中定时任务的实现,特别是针对一些高级用例和最佳实践。

6. 使用APScheduler库实现定时任务

APScheduler(Advanced Python Scheduler)是一个功能强大的Python任务调度库,它提供了基于时间的任务调度功能,并支持多种调度器(如后台线程调度器、进程调度器、基于事件驱动的调度器等)。APScheduler可以很容易地集成到任何Python应用程序中,并且提供了丰富的接口来添加、修改和删除任务。

安装

首先,你需要安装APScheduler库:

pip install APScheduler

示例代码

下面是一个使用APScheduler的示例,它展示了如何设置一个简单的定时任务:

from apscheduler.schedulers.background import BackgroundScheduler
import time

def task():
    print("Task executed at", time.ctime())

# 创建一个后台调度器
scheduler = BackgroundScheduler()

# 添加任务
scheduler.add_job(task, 'interval', seconds=10)

# 启动调度器
scheduler.start()

# 示例:在一段时间后停止调度器(可选)
# try:
#     # 这里是主程序的其他部分
#     while True:
#         time.sleep(2)
# except (KeyboardInterrupt, SystemExit):
#     # 关闭调度器
#     scheduler.shutdown()

# 注意:由于这个示例在脚本的最后没有阻塞,所以调度器会立即开始执行并很快结束(如果没有其他代码阻止它)。
# 在实际应用中,你可能需要在某个循环中等待,或者让这个脚本作为守护进程运行。

# 为了保持这个示例简单并演示调度器的运行,我们可以使用try-except块来模拟主程序的运行,并在收到中断时关闭调度器。
try:
    # 这里让主程序保持运行
    while True:
        time.sleep(2)
except (KeyboardInterrupt, SystemExit):
    scheduler.shutdown()

优缺点

  • 优点
    • 功能强大,支持多种调度器(后台线程、进程、事件驱动)。
    • 提供了丰富的接口来管理任务(添加、修改、删除、暂停、恢复)。
    • 易于集成到任何Python应用程序中。
  • 缺点
    • 相对于简单的time.sleep()schedule库,APScheduler的学习曲线可能稍高一些。
    • 对于非常简单的用例,可能显得过于复杂。

7. 定时任务的最佳实践

1. 确保任务的原子性

确保你的定时任务在执行时是原子性的,即它们应该能够在没有外部干扰的情况下独立完成。这有助于避免任务之间的潜在冲突和数据不一致问题。

2. 捕获异常

在定时任务中,务必捕获并处理可能发生的所有异常。这可以防止因未捕获的异常而导致程序崩溃或停止执行其他任务。

3. 定时任务的日志记录

为你的定时任务添加详细的日志记录,以便在出现问题时能够快速定位和解决问题。日志还可以帮助你了解任务的执行情况和性能。

4. 使用持久化存储

如果你的定时任务需要处理大量数据或需要在多个任务之间共享数据,请考虑使用持久化存储(如数据库或文件系统)。这可以确保数据的可靠性和一致性。

5. 考虑任务的重试机制

对于可能因外部因素(如网络问题、服务不可用等)而失败的任务,考虑实现重试机制。这可以提高任务的可靠性和成功率。

6. 监控和警报

为你的定时任务设置监控和警报系统,以便在任务失败或执行异常时及时得到通知。这可以帮助你快速响应并解决问题。

7. 使用适当的调度器

根据你的具体需求(如任务的数量、执行频率、精度要求等),选择最适合你的调度器。例如,对于需要高精度控制的任务,你可能需要使用基于时间的调度器;而对于需要并行处理大量任务的情况,你可能需要考虑使用基于进程的调度器。

8. 总结

Python提供了多种实现定时任务的方法,从简单的time.sleep()到功能强大的APScheduler库。选择哪种方法取决于你的具体需求、任务的复杂性以及你对系统的控制程度。无论你选择哪种方法,都应该注意任务的原子性、异常处理、日志记录、持久化存储、重试机制、监控和警报以及适当的调度器选择等最佳实践。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1984600.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

安全主机软件是如何有效应对暴力破解的?

在网络安全日益严峻的今天,暴力破解作为一种常见的攻击手段,时刻威胁着企业和个人的账户安全。为了有效抵御这一威胁,主机安全作为一款集实时监测、智能分析、风险预警于一体的主机安全软件,通过多维度、智能化的防护策略&#xf…

便携式气象监测系统的功能与应用

在科技日新月异的今天,气象监测作为农业生产、城市规划、环境保护及灾害预防等领域不可或缺的一环,正经历着前所未有的变革。其中,便携式气象监测系统的出现,如同一股清新的风,吹散了传统气象观测的种种限制&#xff0…

3.达梦数据库基础运维管理

文章目录 前言一、基础数据库管理权限角色管理1.1 DM 系统管理员的类型1.2 角色责则分类 DM 数据库2.1 数据库评估2.2 状态和模式 参考内容 前言 本篇博客为上一篇博客的进阶版,主要针对常规达梦数据库的基本管理上面 一、基础数据库管理 权限角色管理 1.1 DM 系…

【Git企业级开发实战指南②】分支管理、远程操作

目录 一、分支管理1.1理解分支1.2创建分支1.3切换分支1.4合并分支1.5删除分支1.6合并冲突1.7 分支管理策略1.7.1分支策略 1.8bug分支1.9删除临时分支 二、远程操作2.1理解分布式版本控制系统2.2 远程仓库2.2.1 新建远程仓库2.2.2 克隆远程仓库2.2.3向远端仓库推送2.2.4拉取远端…

ROS2 Humble 学习【openEuler】

ROS2 Humble 学习 1 介绍1.1 概述1.2 ROS2 详细介绍1.3 openEuler 安装 ROS2 Humble1.4 ROS2 系统架构 2 ROS2 基础2.1 节点编写、编译、运行【简单示例】节点编写节点编译 g节点运行节点编译 make节点编译 CMakeLists.txtCMake依赖查找流程Python 依赖查找流程 2.2 节点交互、…

MySQL深分页和浅分页

前言 最近有面试过也遇到了问关于深分页问题,在这里简单从MySQL、ES等方面分享一下自己对该问题认识和总结。 一、深分页定义 可以从ES定义上来划分浅分页和深分页的边界,即页数超过10000页为深分页,少于10000页为浅分页。 二、MySQL深分…

数字化时代:蚓链助力企业破局与腾飞!

在当今数字化浪潮汹涌澎湃的时代,企业面临着前新机遇与新挑战。您是否渴望在竞争激烈的市场中实现数字化弯道超车?是否梦想着打造专属自己的独特生意赛道?是否期盼着拥有专享的资源生态圈?如果您的答案是肯定的,那么蚓…

CSP - J day9

一. 题目 (1)早安 思路: (1)cin和scanf读入字符串时遇到空格或换行就停止读入,对于要读入带空格的字符串时,常用 两种方法: // 法一string s;getline( cin, s ); // 法…

OrangePi AIpro学习1 —— 烧写和ssh系统

目录 一、下载烧写工具和系统 二、烧写和启动 2.1 烧写和启动 2.2 烧写失败后的问题解决 三、串口连接到主机 3.1 串口连接到主机 四、网络连接到主机 4.1 修改香橙派IP地址 4.2 win11配置以太网静态ip 4.4 主机和香橙派直连 4.5 主机和香橙派连接到同一个路由器 五…

Hive SQL进阶:掌握间隔连续查询技巧,优化大数据分析(二)

目录 1.访问次数最多的5个用户 2.近 30 天的每日活跃用户数 3.获取1-180天注册活跃留存表 4.学生名次统计 5.最近连续3周连续活跃用户数 6.最近7天内连续3天活跃用户数 7.餐馆营业额变化增长 相关拓展 1.访问次数最多的5个用户 输出每个app 下访问次数最多的5个用户 返…

DC-7靶机渗透测试

DC-7靶机 DC: 7 ~ VulnHub 文章目录 DC-7靶机信息收集web渗透权限提升Drupal后台getshell权限提升靶机总结信息收集 经过扫描得到IP地址为192.168.78.154.其中开启了ssh和80端口,看来立足点就在于web渗透找到漏洞,获取用户密码来进行ssh连接进行寻找提权方案了使用dirb扫描…

Windows平台下内存泄漏检测工具Visual Leak detector介绍(vscode使用)

!!!此工具只能检测配合VC进行代码的内存泄漏检测 1、搜索VLD工具下载 2、配置环境变量 3、在main.cpp中加入#include<vld.h> 4、在CMakeLists.txt中添加 SET(VLD_PATH "xxx") # 链接vld静态库 target_link_libraries(${PROJECT_NAME} PRIVATE ${VLD_PATH})…

学习STM32(2)--STM32单片机GPIO应用

目录 1 引 言 2 实验目的 3 实验内容 3.1掌握STM32F103的GPIO控制 3.1.1 GPIO的分组 3.1.2 GPIO的常用功能 3.1.3 STM32单片机GPIO位结构 3.1.4 STM32单片机GPIO工作模式 3.1.5 STM32的GPIO 输出-点亮LED编程要点 使用GPIO时&#xff0c;按下面步骤进行&#xff1…

antd-5版本table组件修改滚动条样式不生效问题

问题描述 在react项目中使用antd-ProComponents组件库的Protable组件时修改table自带的滚动条样式不生效。 排查记录 一般来说直接table组件库要自定义滚动条的样式&#xff0c;只需要修改 ant-table-body 的样式即可&#xff0c;代码如下&#xff1a; .ant-table-body {&am…

pikachu文件包含漏洞

一&#xff1a;漏洞基础 程序在引用文件的时&#xff0c;引用的文件名存在可控的情况&#xff0c;传入的文件名没有经过合理的校验或校验不严&#xff0c;从而操作了预想之外的文件&#xff0c;就有可能导致文件泄漏和恶意的代码注入&#xff1b; 文件包含漏洞概念 在PHP程序…

如果忘了Linux密码如何重置?

忘记密码是我们常会遇到的情况之一&#xff0c;无论是在操作系统、网站账户、手机、电子邮件还是其他渠道上。 忘记密码是我们常会遇到的情况之一&#xff0c;无论是在操作系统、网站账户、手机、电子邮件还是其他渠道上。有时候如果密码需要符合特定的复杂性要求&#xff0c;…

【C++题解】1023. 判断素数

欢迎关注本专栏《C从零基础到信奥赛入门级&#xff08;CSP-J&#xff09;》 问题&#xff1a;1023. 判断素数 类型&#xff1a;函数&#xff0c;sqrt函数入门 题目描述&#xff1a; 任意输入一个整数&#xff0c;判断它是否为素数。是的话输出 T ,不是的话输出 F。 质数又称…

从传统监控到智能化升级:EasyCVR视频汇聚平台的一站式解决方案

随着科技的飞速发展和社会的不断进步&#xff0c;视频监控已经成为现代社会治安防控、企业管理等场景安全管理中不可或缺的一部分。而在视频监控领域&#xff0c;EasyCVR视频汇聚平台凭借其强大的多协议接入能力&#xff0c;在复杂多变的网络环境中展现出了卓越的性能和广泛的应…

Android 12系统源码_多屏幕(一)多屏幕设备显示Activity

前言 分屏&#xff1a;是指一个屏幕分出多个窗口&#xff0c;分别显示不同应用的界面&#xff0c;这在当前的手机设备中很常见。多屏&#xff1a;是指一个设备存在多个屏幕&#xff0c;这些可能是虚拟屏幕或者实体硬件屏幕&#xff0c;不同的应用同时显示在不同的屏幕中&#…

全面解析:msvcp140_atomic_wait.dll 丢失的解决之道,助你轻松应对

在尝试解决“msvcp140_atomic_wait.dll丢失”的问题时&#xff0c;首先需要确认错误信息的准确性。用户应仔细检查在启动程序或执行特定操作时是否确实出现了这一错误提示。确认错误后&#xff0c;可以进一步采取措施来解决问题。这包括检查系统日志和错误报告&#xff0c;以确…