一日一技:Python自带的优先级调度器

开发 后端
Python 自带一个调度器模块sched,它能为你实现优先级队列/延迟队列和定时队列。

[[395371]]

Python 自带一个调度器模块sched,它能为你实现优先级队列/延迟队列和定时队列。

这个模块的使用非常简单,首先以延迟队列为例:

  1. import sched 
  2.  
  3. def do_work(name): 
  4.     print(f'你好:{name}'
  5.  
  6. sch = sched.scheduler() 
  7. sch.enter(5, 1, do_work, argument=('kingname', )) 
  8. sch.run() 

代码运行以后,会卡在sch.run()这里,5秒钟以后执行do_work('kingname'),运行效果如下图所示:

其中,sch.enter()的第一个参数为延迟的时间,单位为秒,第二个参数为优先级,数字越小优先级越高。当两个任务同时要执行时,优先级高的先执行。但需要注意的是,如果你这样写:

  1. import sched 
  2.  
  3. def do_work(name): 
  4.     print(f'你好:{name}'
  5.  
  6. sch = sched.scheduler() 
  7. sch.enter(5, 2, do_work, argument=('产品经理', )) 
  8. sch.enter(5, 1, do_work, argument=('kingname', )) 
  9. sch.run() 

那么先打印出来的是你好:产品经理,如下图所示:

为什么这里优先级失效了?1的优先级大于2,应该先运行下面的才对啊。

这是由于,只有当两个任务同时运行的时候,才会去检查优先级。如果两个任务触发的时间一前一后,那么还轮不到比较优先级。由于延迟队列的延迟是相对于当前运行这一行代码的时间来计算的,后一行代码比前一行代码晚了几毫秒,所以实际上产品经理这一行会先到时间,所以就会先运行。

为了使用绝对的精确时间,我们可以使用另外一个方法:

  1. import sched 
  2. import time 
  3. import datetime 
  4.  
  5. def do_work(name): 
  6.     print(f'你好:{name}'
  7.  
  8. sch = sched.scheduler(time.timetime.sleep) 
  9. start_time = datetime.datetime.now() + datetime.timedelta(seconds=10) 
  10. start_time_ts = start_time.timestamp() 
  11. sch.enterabs(start_time_ts, 2, do_work, argument=('产品经理', )) 
  12. sch.enterabs(start_time_ts, 1, do_work, argument=('kingname', )) 
  13. sch.run() 

运行效果如下图所示:

sch.enterabc()的第一个参数是任务开始时间的时间戳,这是一个绝对时间,这个时间可以使用datetime模块来生成,或者其他你熟悉的方式。后面的参数和sch.enter()完全一样。

如果你要运行的函数带有多个参数或者默认参数,那么可以使用下面的方式传入参数:

  1. import sched 
  2. import time 
  3. import datetime 
  4.  
  5. def do_work(name, place, work='写代码'): 
  6.     print(f'你好:{name},你在:{place}{work}'
  7.  
  8. sch = sched.scheduler(time.timetime.sleep) 
  9. start_time = datetime.datetime.now() + datetime.timedelta(seconds=10) 
  10. start_time_ts = start_time.timestamp() 
  11. sch.enter(5, 2, do_work, argument=('产品经理''杭州'), kwargs={'work''写需求文档'}) 
  12. sch.enterabs(start_time_ts, 1, do_work, argument=('kingname''产品经理旁边'), kwargs={'work''看着她'}) 
  13. sch.run() 

 

argument参数对应的元组存放普通参数,kwargs对应的字典存放带参数名的参数。

 

责任编辑:武晓燕 来源: 未闻Code
相关推荐

2021-04-05 14:47:55

Python多线程事件监控

2021-04-12 21:19:01

PythonMakefile项目

2021-04-27 22:15:02

Selenium浏览器爬虫

2021-09-13 20:38:47

Python链式调用

2024-07-30 08:16:18

Python代码工具

2024-07-30 08:11:16

2021-03-12 21:19:15

Python链式调用

2021-07-27 21:32:57

Python 延迟调用

2021-10-15 21:08:31

PandasExcel对象

2022-06-28 09:31:44

LinuxmacOS系统

2022-03-12 20:38:14

网页Python测试

2021-11-12 05:00:43

装饰器代码功能

2023-10-29 09:16:49

代码安全命令

2024-02-20 22:13:48

Python项目Java

2020-05-19 13:55:38

Python加密密码

2023-10-28 12:14:35

爬虫JavaScriptObject

2021-04-19 23:29:44

MakefilemacOSLinux

2022-05-02 16:27:01

JavaScriptHTMLPython

2022-03-07 09:14:04

Selenium鼠标元素

2021-10-03 20:08:29

HTTP2Scrapy
点赞
收藏

51CTO技术栈公众号