1、代码实现
# -*- coding:utf-8 -*-
import os
import sys
import threading
from apscheduler.schedulers.blocking import BlockingScheduler
from datetime import datetime
import time
def timer(n):
while True:
print(datetime.now().strftime("%Y-%m-%d %H:%M:%S"))
time.sleep(n)
class myshcedule(object):
# @staticmethod
def job2(self, spark):
print("hello : ", spark)
# @staticmethod
def start_jobs(self, spark):
scheduler = BlockingScheduler()
scheduler.add_job(func=self.job2, args=[spark],
trigger="interval", seconds=5)
scheduler.start()
# @staticmethod
def update_thread(self, spark):
thread = threading.Thread(target=self.start_jobs, args=[spark])
thread.start()
print("start")
if __name__ == '__main__':
app = myshcedule()
app.update_thread("666")
timer(10)
相关参数介绍
## 按间隔执行
"""
trigger:可选 `date`, `interval` or `cron`)
interval:
weeks (int) – 间隔几周
days (int) – 间隔几天
hours (int) – 间隔几小时
minutes (int) – 间隔几分钟
seconds (int) – 间隔多少秒
start_date (datetime|str) – 开始日期
end_date (datetime|str) – 结束日期
timezone (datetime.tzinfo|str) – 时区
cron:
year (int|str) – 年,4位数字
month (int|str) – 月 (范围1-12)
day (int|str) – 日 (范围1-31)
week (int|str) – 周 (范围1-53)
day_of_week (int|str) – 周内第几天或者星期几 (范围0-6 或者 mon,tue,wed,thu,fri,sat,sun)
hour (int|str) – 时 (范围0-23)
minute (int|str) – 分 (范围0-59)
second (int|str) – 秒 (范围0-59)
start_date (datetime|str) – 最早开始日期(包含)
end_date (datetime|str) – 最晚结束时间(包含)
timezone (datetime.tzinfo|str) – 指定时区
"""
## 按给定时间执行
# scheduler.add_job(timedTask, 'date', run_date="2019-10-17 13:36:00")
# scheduler.add_job(main, 'date', run_date=datetime(2019, 10, 17, 15, 6, 0))
# scheduler.add_job(timedTask, 'date', run_date=date(2019, 10, 17))
## 按时间间隔执行
# scheduler.add_job(timedTask, 'interval', seconds=3)
2、输出结果
- 定时任务每 5 秒打印一次 :“hello : 666”
- 主线程任务每 10 秒打印一次当前时间 :“2020-09-02 14:52:28”
定时任务和多线程任务创建函数中都需要加 start() 方法.