Python中schedule模块定时任务的使用方法(2)
作者:redrose2100? 发布时间:2023-09-01 09:59:59
上一篇文章Python中schedule模块关于定时任务使用方法
1 设置时间间隔随机数
在有一些场景下,为了模拟比较自然的情景,需要采用随机的时间间隔,这就派上用场了
如下代码,设置随机间隔从2秒到10秒之间取随机数
import schedule
import time
def do_func(name,age):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+" in do func : 姓名:"+name+" 年龄:"+str(age))
def main():
# 定义定时任务时直接打标签
schedule.every(2).to(10).seconds.do(do_func,"张三丰",100).tag("demo1","demo2")
while True:
schedule.run_pending()
if __name__=="__main__":
main()
执行结果如下,可以看出,确实在随机时间间隔
2022-05-25 01:02:45 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:02:50 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:02:53 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:02:59 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:01 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:05 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:08 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:13 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:17 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:03:22 in do func : 姓名:张三丰 年龄:100
2 设置定时任务执行到指定时间
如下均为指定到固定时间,这里因为是固定时间,就不再演示执行的结果了
import schedule
from datetime import datetime, timedelta, time
def job():
print('in job...')
# 每小时执行一次,直到今天的 18:30为止
schedule.every(1).hours.until("18:30").do(job)
# 每小时执行一次,直到 2030-01-01 18:33为止
schedule.every(1).hours.until("2030-01-01 18:33").do(job)
# 在未来8小时内,每小时执行一次
schedule.every(1).hours.until(timedelta(hours=8)).do(job)
# 每小时执行一次,直到今天的 11:33:42
schedule.every(1).hours.until(time(11, 33, 42)).do(job)
# 每小时执行一次,直到 2030-01-01 18:33:20 为止
schedule.every(1).hours.until(datetime(2030, 1, 1, 18, 33, 20)).do(job)
3 计算当前到下一次执行的时间差单位为秒
如下,设置每两个小时执行一次,如下可以计算出到下一次执行的时间为7200秒
结果如下:
import schedule
import time
def do_func(name,age):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+" in do func : 姓名:"+name+" 年龄:"+str(age))
def main():
# 定义定时任务时直接打标签
schedule.every(2).hours.do(do_func,"张三丰",100)
t=schedule.idle_seconds()
print(t)
if __name__=="__main__":
main()
7200.0
立刻执行所有的任务,不管他们是如何定时的
(1)首先看一下,不使用立刻执行所有的任务时:
代码如下:
import schedule
import time
def do_func(name,age):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+" in do func : 姓名:"+name+" 年龄:"+str(age))
def main():
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
schedule.every(3).seconds.do(do_func,"张三丰",100)
while True:
schedule.run_pending()
if __name__=="__main__":
main()
执行结果如下,即启动任务后,过一个时间间隔才执行
2022-05-25 01:43:04
2022-05-25 01:43:07 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:43:10 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:43:13 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:43:16 in do func : 姓名:张三丰 年龄:100
(2)设置立刻执行
代码如下,设置立刻执行
import schedule
import time
def do_func(name,age):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+" in do func : 姓名:"+name+" 年龄:"+str(age))
def main():
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
schedule.every(3).seconds.do(do_func,"张三丰",100)
schedule.run_all()
while True:
schedule.run_pending()
if __name__=="__main__":
main()
可以看出,此时任务立刻执行,不会等3秒再执行,立刻执行之后再开始按照定时任务设置的规则去执行
2022-05-25 01:46:17
2022-05-25 01:46:17 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:46:20 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:46:23 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:46:26 in do func : 姓名:张三丰 年龄:100
(3)立刻执行可以设置延时,这里的延时是指延长这些时间之后,定时任务才生效
代码如下:
import schedule
import time
def do_func(name,age):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))+" in do func : 姓名:"+name+" 年龄:"+str(age))
def main():
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
schedule.every(3).seconds.do(do_func,"张三丰",100)
schedule.run_all(delay_seconds=10)
while True:
schedule.run_pending()
if __name__=="__main__":
main()
执行结果如下,可以看出,按照这种方式设置,也是立刻执行,只不过立刻执行之后,要过10秒之后定时任务才失效,这里需要特别注意,这里的延时不是说延长这么多时间才执行
2022-05-25 01:48:20
2022-05-25 01:48:20 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:48:30 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:48:33 in do func : 姓名:张三丰 年龄:100
2022-05-25 01:48:36 in do func : 姓名:张三丰 年龄:100
来源:http://blog.redrose2100.com/article/305


猜你喜欢
- Java读取数据库表package com.easycrud.builder;import com.easycrud.utils.Prope
- 今天周五,很闲,坐在电脑前没什么事可做,产品线的人也没提什么新的需求,可能下周会有新的需求和工作安排,但那是下周的事了。今天就想写点技术的东
- 1. 确认已经安装了NT/2000和SQL Server的最新补丁程序,不用说大家应该已经安装好了,但是我觉得最好还是在这里提醒一下。2.
- 前言最近在用python写一个项目,发现一个很恶心的bug,就是同由一个类生成的两个实例之间的数据竟然会相互影响,这让我非常不解。后来联想到
- 本篇文章主要介绍在插入数据到表中遇到键重复避免插入重复值的处理方法,主要涉及到IGNORE,ON DUPLICATE KEY UPDATE,
- 很多人看到PHP就以为是程序员,就以为钱很多(虽然是事实),但是也要考虑下自己是不是适合这一行,知道PHP是什么吗?PHP都有什么样的功能,
- 在设计网页时,没有比页面的外观更重要的了。所以,如果发现设计人员十分关注字体及字体大小,我并不感到惊奇。使用CSS来编辑字体有各种各样的方法
- mysql存储引擎概述什么是存储引擎?MySQL中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制
- 关于在asp中不使用组件使得脚本sleep的办法还比较少见,可能比较好的办法是创建同步的xmlhttp request,直到获得的时间达到某
- 本文实例讲述了JavaScript简单计算人的年龄的方法。分享给大家供大家参考,具体如下:注意Date()类型转换,否则会出现NaN的错误b
- 关于保存h5模型、权重网上的示例非常多,也非常简单。主要有以下两个函数:1、keras.models.load_model() 读取网络、权
- 1. 在router/index.js中使用meta属性的title设置好每个路由对应的title值/* router/index.js:
- tensorflow版本1.4获取变量维度是一个使用频繁的操作,在tensorflow中获取变量维度主要用到的操作有以下三种:Tensor.
- 多数应用场景下,我们需要对重要数据进行备份、并放置到一个安全的地方,以备不时之需。常见的 MySQL 数据备份方式有,直接打包复制对应的数据
- 需求:NMS中的IOU相关,是选择一个最大或者可信度最高的框框保留。而我们现在试需要将重叠框框合并为一个大的框框,所以不能直接用上面的。并且
- 二维矩阵的transpose函数:不晓得该怎么起头,直接上干货。transpose()简单来说,就相当于数学中的转置,在矩阵中,转置就是把行
- 前言最近组长安排着做一个项目,h5的应用下载项目,想着做起来还是比较容易,可是看到提出的需求,我就有点懵逼了!需要对应用的下载进行统计!!!
- ucky-canvas 介绍一个基于 Js + Canvas 的【大转盘 & 九宫格 & * 】抽奖, 致力于为 web
- 简介使用的核心模块是python标准库中的zipfile模块。这个模块可以实现zip文件的各种功能,具体可以查看官方参考文档。这里的暴力破解
- 一,前言我们现在拿到了一个十分庞大的数据集。是json文件,里面存储了将近十万个数据,现在要对其中的数据进行清洗处理。二,python模块i