| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- # -*- coding: utf-8 -*-
- # Author : Charley
- # Python : 3.10.8
- # Date : 2026/1/29 16:31
- import time
- import schedule
- import threading
- from loguru import logger
- from super_vault_daily_spider import cxx_daily_main
- from super_vault_on_sale_spider import cxx_sale_main
- logger.remove()
- logger.add("./logs/{time:YYYYMMDD}.log", encoding='utf-8', rotation="00:00",
- format="[{time:YYYY-MM-DD HH:mm:ss.SSS}] {level} {message}",
- level="DEBUG", retention="7 day")
- def run_threaded(job_func, *args, **kwargs):
- """
- 在新线程中运行给定的函数,并传递参数。
- :param job_func: 要运行的目标函数
- :param args: 位置参数
- :param kwargs: 关键字参数
- """
- job_thread = threading.Thread(target=job_func, args=args, kwargs=kwargs)
- job_thread.start()
- def schedule_task():
- """
- 爬虫模块的启动文件
- """
- # 立即运行一次任务
- run_threaded(cxx_daily_main, log=logger)
- # time.sleep(5)
- run_threaded(cxx_sale_main, log=logger)
- # 设置定时任务
- schedule.every().day.at("07:01").do(run_threaded, cxx_daily_main, log=logger)
- schedule.every().hour.do(run_threaded, cxx_sale_main, log=logger)
- while True:
- schedule.run_pending()
- time.sleep(1)
- if __name__ == '__main__':
- schedule_task()
|