agc_main.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. from common import Feishu, Material
  2. from common.sql_help import sqlHelp
  3. from video_agc.agc_video_method import AgcVidoe
  4. import concurrent.futures
  5. import schedule
  6. import time
  7. # 记录今天已经返回的用户名
  8. returned_usernames_today = set()
  9. def video_start(user_data):
  10. global returned_usernames_today
  11. user_data_mark = user_data["mark"]
  12. # 开始准备执行生成视频脚本
  13. if user_data_mark is not None and user_data_mark in returned_usernames_today:
  14. print(f"视频脚本参数中的用户名 {user_data_mark} 今天已经返回过,不再启动线程。")
  15. return # 如果返回了某个用户名,并且今天已经返回过,则不启动线程
  16. elif user_data_mark is not None:
  17. print(f"视频脚本参数{user_data}")
  18. mark = AgcVidoe.video_stitching(user_data)
  19. if mark:
  20. returned_usernames_today.add(mark)
  21. # 定义定时任务
  22. def video_task():
  23. print("开始执行生成视频脚.")
  24. data = Material.feishu_list()
  25. # 创建一个线程池
  26. with concurrent.futures.ThreadPoolExecutor() as executor:
  27. futures = [executor.submit(video_start, user_data) for user_data in data]
  28. # 等待所有任务执行完成
  29. for future in concurrent.futures.as_completed(futures):
  30. # 获取每个任务的执行结果
  31. result = future.result()
  32. print("处理结果:", result)
  33. print("执行生成视频脚结束")
  34. schedule.every(10).minutes.do(video_task)
  35. # 每天0点清空集合
  36. schedule.every().day.at("00:00").do(lambda: returned_usernames_today.clear())
  37. def job_feishu_bot():
  38. name_list = Material.feishu_name()
  39. count_list = sqlHelp.get_count_list(name_list)
  40. Feishu.bot('recommend', 'AGC视频', f'{"".join(count_list)}', 'all')
  41. print("机器人通知完成")
  42. # 每天下午1:30执行任务
  43. schedule.every().day.at("15:00").do(job_feishu_bot)
  44. while True:
  45. schedule.run_pending()
  46. time.sleep(1)
  47. # list = Material.feishu_list()
  48. # AgcVidoe.video_stitching(list)
  49. # print(list)