【python】python APScheduler 框架

2023-12-10 17:58
文章标签 python apscheduler 框架

本文主要是介绍【python】python APScheduler 框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python APScheduler 框架,模仿Java的Quartz框架写的,强大给力。

它的主页是:http://packages.python.org/APScheduler/index.html

提问的地方:http://groups.google.com/group/apscheduler (老外很认真的回答你的问题)

它的按照很简单:参考主要的install就可以了,就两三步

例子如下:

 

Python代码   收藏代码
  1. from apscheduler.scheduler import Scheduler  
  2. import time  
  3.   
  4. # Start the scheduler  
  5. sched = Scheduler()  
  6.   
  7.   
  8. def job_function():  
  9.     print "Hello World"  
  10.   
  11. print 'start to sleep'  
  12. print 'wake'  
  13. sched.daemonic = False  
  14. sched.add_cron_job(job_function,day_of_week='mon-fri', hour='*', minute='0-59',second='*/5')  
  15. sched.start()  

 这个是最简单的例子(目前我初学,呵呵)

这里要提到的是:

apscheduler会创建一个线程,这个线程默认是daemon=True,也就是默认的是线程守护的。

在上面的代码里面,要是不加上sched.daemonic=False的话,这个脚本就不会运行。

因为上面的脚本要是没有sched.daemonic=False的话,它会创建一个守护线程。这个过程中,会创建scheduler的实例。但是由于脚本很小,运行速度很快,主线程mainthread会马上结束,而此时定时任务的线程还没来得及执行,就跟随主线程结束而结束了。(守护线程和主线程之间的关系决定的)。要让脚本运行正常,必须设置该脚本为非守护线程。sched.daemonic=False

=================== end ======================

 

补充:

 

Python代码   收藏代码
  1. #-*-coding:utf-8-*-  
  2. from apscheduler.scheduler import Scheduler  
  3.   
  4. def job_function(a):  
  5.     print a  
  6.   
  7. if __name__ == '__main__':  
  8.     hello = 'hello world'  
  9.     sched = Scheduler(daemonic=False# 注意这里,要设置 daemonic=False  
  10.     sched.add_cron_job(job_function, day_of_week='mon-fri', hour='*', minute='0-59', second='*/5', args=[hello]) # args=[] 用来给job函数传递参数  
  11.     sched.start()  
  12.   
  13. # ----------- 源码  -------------------------------     
  14. #   def add_cron_job(self, func, year=None, month=None, day=None, week=None,  
  15. #                    day_of_week=None, hour=None, minute=None, second=None,  
  16. #                    start_date=None, args=None, kwargs=None, **options):  
  17. #       """  
  18. #       Schedules a job to be completed on times that match the given  
  19. #       expressions.  
  20. #  
  21. #       :param func: callable to run  
  22. #       :param year: year to run on  
  23. #       :param month: month to run on  
  24. #       :param day: day of month to run on  
  25. #       :param week: week of the year to run on  
  26. #       :param day_of_week: weekday to run on (0 = Monday)  
  27. #       :param hour: hour to run on  
  28. #       :param second: second to run on  
  29. #       :param args: list of positional arguments to call func with  
  30. #       :param kwargs: dict of keyword arguments to call func with  
  31. #       :param name: name of the job  
  32. #       :param jobstore: alias of the job store to add the job to  
  33. #       :param misfire_grace_time: seconds after the designated run time that  
  34. #           the job is still allowed to be run  
  35. #       :return: the scheduled job  
  36. #       :rtype: :class:`~apscheduler.job.Job`  
  37. #       """  
  38. #  
 

这篇关于【python】python APScheduler 框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/477865

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',