91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python項目中如何安裝和使用APScheduler定時任務

發布時間:2020-11-09 16:15:15 來源:億速云 閱讀:445 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關Python項目中如何安裝和使用APScheduler定時任務,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1、簡介

APScheduler是一個 Python 定時任務框架,使用起來十分方便。提供了基于日期、固定時間間隔以及 crontab 類型的任務,并且可以持久化任務、并以 daemon 方式運行應用。

2、APScheduler四個組件

APScheduler 四個組件分別為:觸發器(trigger),作業存儲(job store),執行器(executor),調度器(scheduler)。

觸發器(trigger)

包含調度邏輯,每一個作業有它自己的觸發器,用于決定接下來哪一個作業會運行。除了他們自己初始配置意外,觸發器完全是無狀態的

APScheduler 有三種內建的 trigger:

  • date: 特定的時間點觸發
  • interval: 固定時間間隔觸發
  • cron: 在特定時間周期性地觸發

作業存儲(job store)

存儲被調度的作業,默認的作業存儲是簡單地把作業保存在內存中,其他的作業存儲是將作業保存在數據庫中。一個作業的數據講在保存在持久化作業存儲時被序列化,并在加載時被反序列化。調度器不能分享同一個作業存儲。
APScheduler 默認使用 MemoryJobStore,可以修改使用 DB 存儲方案

執行器(executor)

處理作業的運行,他們通常通過在作業中提交制定的可調用對象到一個線程或者進城池來進行。當作業完成時,執行器將會通知調度器。

最常用的 executor 有兩種:

  • ProcessPoolExecutor
  • ThreadPoolExecutor

調度器(scheduler)

通常在應用中只有一個調度器,應用的開發者通常不會直接處理作業存儲、調度器和觸發器,相反,調度器提供了處理這些的合適的接口。配置作業存儲和執行器可以在調度器中完成,例如添加、修改和移除作業

2、安裝

$ pip install apscheduler

接下來我們看下簡單的幾個示例:

===============interval: 固定時間間隔觸發===============
from apscheduler.schedulers.blocking import BlockingScheduler
from datetime import datetime

def job():
  print(datetime.now().strftime("%Y-%m-%d %H:%M:%S"))
# 定義BlockingScheduler
sched = BlockingScheduler()
sched.add_job(job, 'interval', seconds=5) 
sched.start()
===============cron: 特定時間周期性地觸發===============
import time
from apscheduler.schedulers.blocking import BlockingScheduler

def job(text):
  t = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))
  print('{} --- {}'.format(text, t))

scheduler = BlockingScheduler()
# 在每天22點,每隔 1分鐘 運行一次 job 方法
scheduler.add_job(job, 'cron', hour=17, minute='*/1', args=['job1'])
# 在每天22和23點的25分,運行一次 job 方法
scheduler.add_job(job, 'cron', hour='22-23', minute='25', args=['job2'])

scheduler.start()

通過裝飾器scheduled_job()添加方法

import time
from apscheduler.schedulers.blocking import BlockingScheduler

scheduler = BlockingScheduler()

@scheduler.scheduled_job('interval', seconds=5)
def job1():
  t = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))
  print('job1 --- {}'.format(t))

@scheduler.scheduled_job('cron', second='*/7')
def job2():
  t = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))
  print('job2 --- {}'.format(t))

scheduler.start()

上述就是小編為大家分享的Python項目中如何安裝和使用APScheduler定時任務了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武冈市| 故城县| 鄢陵县| 新乡市| 通海县| 罗山县| 辽阳县| 石泉县| 宣恩县| 汉中市| 大田县| 乐山市| 聊城市| 北流市| 昆山市| 广丰县| 班戈县| 武乡县| 如东县| 葫芦岛市| 利辛县| 团风县| 黄山市| 芦溪县| 丹阳市| 张掖市| 苗栗县| 龙山县| 新民市| 梓潼县| 五常市| 通道| 景德镇市| 肇东市| 康马县| 福泉市| 九江县| 合川市| 门头沟区| 利津县| 射洪县|