您好,登錄后才能下訂單哦!
這篇文章主要講解了Python任務調度模塊APScheduler的用法,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
APScheduler是一個Python定時任務框架,使用起來十分方便。提供了基于日期、固定時間間隔以及crontab類型的任務,并且可以持久化任務、并以daemon方式運行應用。
在APScheduler中有四個組件:
你需要選擇合適的調度器,這取決于你的應用環境和你使用APScheduler的目的。通常最常用的兩個:
BlockingScheduler:當調度器是你應用中唯一要運行的東西時使用。
BackgroundScheduler:當你不運行任何其他框架時使用,并希望調度器在你應用的后臺執行。
作業存儲
支持4中作業存儲,分別是:MemoryJobStore(存儲在內存中)、sqlalchemy(關系型數據庫)、mongodb(文檔數據庫)、redis(內存型鍵值對數據庫)
觸發方式
date:固定日期觸發器:任務只運行一次,運行完畢自動清除;若錯過指定運行時間,任務不會被創建
interval:時間間隔觸發器,每個一定時間間隔執行一次。
cron:cron風格的任務觸發。
作業操作
1. 添加作業:上面是通過add_job()來添加作業,另外還有一種方式是通過scheduled_job()修飾器來修飾函數。
@sched.scheduled_job('cron', id='my_job_id', day='last sun')
def some_decorated_task():
print("I am printed at 00:00:00 on the last Sunday of every month!")
2. 移除作業
job = scheduler.add_job(myfunc,'interval', minutes=2)
job.remove()
Same,using an explicit job ID:
scheduler.add_job(myfunc,'interval', minutes=2, id='my_job_id')
scheduler.remove_job('my_job_id')
3. 暫停和恢復作業
暫停作業:
–apscheduler.job.Job.pause()
–apscheduler.schedulers.base.BaseScheduler.pause_job()
恢復作業:
–apscheduler.job.Job.resume()
–apscheduler.schedulers.base.BaseScheduler.resume_job()
4. 獲得job列表
獲得調度作業的列表,可以使用get_jobs()來完成,它會返回所有的job實例。或者使用print_jobs()來輸出所有格式化的作業列表。
5. 修改作業
def some_decorated_task():
print("I am printed at 00:00:00 on the last Sunday of every month!")
6. 關閉調度器
默認情況下調度器會等待所有正在運行的作業完成后,關閉所有的調度器和作業存儲。如果你不想等待,可以將wait選項設置為False。
scheduler.shutdown()
scheduler.shutdown(wait=False)
作業運行的控制
add_job的第二個參數是trigger,它管理著作業的調度方式。它可以為date, interval或者cron。對于不同的trigger,對應的參數也相同。
看完上述內容,是不是對Python任務調度模塊APScheduler的用法有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。