agc_assign_main.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. import re
  2. from common import Material, Common, Feishu
  3. from video_agc.agc_video_method import AgcVidoe
  4. import concurrent.futures
  5. import schedule
  6. import time
  7. # 记录今天已经返回的用户名
  8. returned_usernames_today = []
  9. def video_start(user_data):
  10. global returned_usernames_today
  11. user_data_mark = user_data["mark"]
  12. video_call = user_data["video_call"]
  13. mark_name = user_data['mark_name']
  14. # 开始准备执行生成视频脚本
  15. if user_data_mark is not None and user_data_mark in returned_usernames_today:
  16. Common.logger("video").info(f"视频脚本参数中的用户名 {user_data_mark} 今天已经返回过,不再启动线程。今天已经返回的用户名:{returned_usernames_today}")
  17. print(f"视频脚本参数中的用户名 {user_data_mark} 今天已经返回过,不再启动线程。")
  18. return # 如果返回了某个用户名,并且今天已经返回过,则不启动线程
  19. if video_call is not None and video_call in returned_usernames_today:
  20. print(f"视频脚本参数中的脚本{user_data_mark} 今天已经返回过,不再启动线程。")
  21. return # 如果返回了某个用户名,并且今天已经返回过,则不启动线程
  22. else:
  23. print(f"视频脚本参数{user_data}")
  24. mark = AgcVidoe.video_gs_stitching(user_data)
  25. print(f"返回用户名{mark}")
  26. if mark:
  27. Common.logger("video").info(f"返回用户名{mark}")
  28. returned_usernames_today.append(mark)
  29. zd_count = user_data["zd_count"] # 生成总条数
  30. # 总条数
  31. result = re.match(r'([^0-9]+)', user_data_mark).group()
  32. all_count = AgcVidoe.get_link_gs_count(result)
  33. if all_count >= int(zd_count):
  34. Feishu.bot('recommend', 'AGC完成通知', '今日脚本跟随视频拼接任务完成啦~', user_data_mark.split("-")[0], mark_name)
  35. gs_name_list = Material.feishu_gs_list()
  36. video_start(gs_name_list[0])
  37. # def clear_returned_usernames():
  38. # returned_usernames_today.clear()
  39. # print("returned_usernames_today 已清空")
  40. #
  41. # # 定义定时任务
  42. # def video_task():
  43. # print("开始执行生成视频脚.")
  44. # data = Material.feishu_gs_list()
  45. # # 创建一个线程池
  46. # with concurrent.futures.ThreadPoolExecutor() as executor:
  47. # futures = [executor.submit(video_start, user_data) for user_data in data]
  48. # # 等待所有任务执行完成
  49. # for future in concurrent.futures.as_completed(futures):
  50. # try:
  51. # # 获取每个任务的执行结果
  52. # result = future.result()
  53. # print("处理结果:", result)
  54. # except Exception as e:
  55. # print("处理任务时出现异常:", e)
  56. # print("执行生成视频脚结束")
  57. #
  58. # # 每天0点10清空集合
  59. # schedule.every().day.at("00:05").do(clear_returned_usernames)
  60. #
  61. # #每10分钟执行次脚本
  62. # schedule.every(10).minutes.do(video_task)
  63. #
  64. #
  65. # while True:
  66. # schedule.run_pending()
  67. # time.sleep(1)