mirror of
https://github.com/Zippland/Bubbles.git
synced 2026-01-19 01:21:15 +08:00
95 lines
2.7 KiB
Python
95 lines
2.7 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
import time
|
|
import logging
|
|
from typing import Any, Callable
|
|
|
|
import schedule
|
|
|
|
# 获取模块级 logger
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class Job(object):
|
|
def __init__(self) -> None:
|
|
pass
|
|
|
|
def onEverySeconds(self, seconds: int, task: Callable[..., Any], *args, **kwargs) -> None:
|
|
"""
|
|
每 seconds 秒执行
|
|
:param seconds: 间隔,秒
|
|
:param task: 定时执行的方法
|
|
:return: None
|
|
"""
|
|
schedule.every(seconds).seconds.do(task, *args, **kwargs)
|
|
|
|
def onEveryMinutes(self, minutes: int, task: Callable[..., Any], *args, **kwargs) -> None:
|
|
"""
|
|
每 minutes 分钟执行
|
|
:param minutes: 间隔,分钟
|
|
:param task: 定时执行的方法
|
|
:return: None
|
|
"""
|
|
schedule.every(minutes).minutes.do(task, *args, **kwargs)
|
|
|
|
def onEveryHours(self, hours: int, task: Callable[..., Any], *args, **kwargs) -> None:
|
|
"""
|
|
每 hours 小时执行
|
|
:param hours: 间隔,小时
|
|
:param task: 定时执行的方法
|
|
:return: None
|
|
"""
|
|
schedule.every(hours).hours.do(task, *args, **kwargs)
|
|
|
|
def onEveryDays(self, days: int, task: Callable[..., Any], *args, **kwargs) -> None:
|
|
"""
|
|
每 days 天执行
|
|
:param days: 间隔,天
|
|
:param task: 定时执行的方法
|
|
:return: None
|
|
"""
|
|
schedule.every(days).days.do(task, *args, **kwargs)
|
|
|
|
def onEveryTime(self, times: int, task: Callable[..., Any], *args, **kwargs) -> None:
|
|
"""
|
|
每天定时执行
|
|
:param times: 时间字符串列表,格式:
|
|
- For daily jobs -> HH:MM:SS or HH:MM
|
|
- For hourly jobs -> MM:SS or :MM
|
|
- For minute jobs -> :SS
|
|
:param task: 定时执行的方法
|
|
:return: None
|
|
|
|
例子: times=["10:30", "10:45", "11:00"]
|
|
"""
|
|
if not isinstance(times, list):
|
|
times = [times]
|
|
|
|
for t in times:
|
|
schedule.every(1).days.at(t).do(task, *args, **kwargs)
|
|
|
|
def runPendingJobs(self) -> None:
|
|
schedule.run_pending()
|
|
|
|
|
|
if __name__ == "__main__":
|
|
# 设置测试用的日志配置
|
|
logging.basicConfig(
|
|
level=logging.INFO,
|
|
format='%(asctime)s - %(levelname)s - %(name)s - %(message)s'
|
|
)
|
|
|
|
def printStr(s):
|
|
logger.info(s)
|
|
|
|
job = Job()
|
|
job.onEverySeconds(59, printStr, "onEverySeconds 59")
|
|
job.onEveryMinutes(59, printStr, "onEveryMinutes 59")
|
|
job.onEveryHours(23, printStr, "onEveryHours 23")
|
|
job.onEveryDays(1, printStr, "onEveryDays 1")
|
|
job.onEveryTime("23:59", printStr, "onEveryTime 23:59")
|
|
|
|
while True:
|
|
job.runPendingJobs()
|
|
time.sleep(1)
|