start_pokemon_spider.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. # -*- coding: utf-8 -*-
  2. # Author : Charley
  3. # Python : 3.10.8
  4. # Date : 2025/8/15 17:53
  5. import time
  6. import schedule
  7. import threading
  8. from loguru import logger
  9. from jp_pokemon_card_spider import JPPokemonCardSpider
  10. from us_pokemon_card_spider import us_pokemon_main
  11. from fan_pokemon_card_spider import fz_pokemon_main
  12. logger.remove()
  13. logger.add("./logs/{time:YYYYMMDD}.log", encoding='utf-8', rotation="00:00",
  14. format="[{time:YYYY-MM-DD HH:mm:ss.SSS}] {level} {message}",
  15. level="DEBUG", retention="1 day")
  16. def run_threaded(job_func, *args, **kwargs):
  17. """
  18. 在新线程中运行给定的函数,并传递参数。
  19. :param job_func: 要运行的目标函数
  20. :param args: 位置参数
  21. :param kwargs: 关键字参数
  22. """
  23. job_thread = threading.Thread(target=job_func, args=args, kwargs=kwargs)
  24. job_thread.start()
  25. def schedule_task():
  26. """
  27. 两个爬虫模块的启动文件
  28. bidding_main
  29. weika_change_card_by_id_spider
  30. change_card_main
  31. """
  32. # 立即运行一次任务
  33. jp_spider = JPPokemonCardSpider(log=logger)
  34. run_threaded(jp_spider.run)
  35. #
  36. run_threaded(us_pokemon_main(log=logger))
  37. run_threaded(fz_pokemon_main(log=logger))
  38. # 设置定时任务
  39. schedule.every().day.at("02:01").do(run_threaded, JPPokemonCardSpider(log=logger).run)
  40. schedule.every().day.at("01:01").do(run_threaded, us_pokemon_main, log=logger)
  41. schedule.every().tuesday.at("02:01").do(run_threaded, fz_pokemon_main, log=logger)
  42. #
  43. # schedule.every().day.at("03:01").do(run_threaded, hoopi_mall_card_main, log=logger)
  44. # schedule.every().day.at("04:01").do(run_threaded, hoopi_mall_group_main, log=logger)
  45. while True:
  46. schedule.run_pending()
  47. time.sleep(1)
  48. if __name__ == '__main__':
  49. schedule_task()