|
@@ -131,7 +131,7 @@ class CarryViode:
|
|
|
"【 搬运&改造效率工具失败通知 】")
|
|
|
return
|
|
|
if not url:
|
|
|
- in_carry_video_data(REDIS_NAME, data)
|
|
|
+ in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
|
|
|
logger.info(f"[+] {url}没有获取到视频链接,等待重新处理")
|
|
|
AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
"没有获取到视频链接,等待重新处理", "1002", str(data))
|
|
@@ -144,22 +144,19 @@ class CarryViode:
|
|
|
"https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
|
|
|
"【 搬运&改造效率工具失败通知 】")
|
|
|
return
|
|
|
- logger.info(f"[+] {url}开始处理标题")
|
|
|
- if data["title_category"] == "AI标题" or data["trailer_share"] == "AI标题":
|
|
|
- title = GPT4o.get_ai_title(original_title if data["title_category"] == "原标题" else data["title_category"])
|
|
|
- else:
|
|
|
- title = original_title if data["title_category"] == "原标题" else data["title_category"]
|
|
|
+
|
|
|
logger.info(f"[+] {url}开始下载视频")
|
|
|
video_path = DownLoad.download_video(url, file_path)
|
|
|
# video_path = Oss.download_video_oss(url, file_path)
|
|
|
- if not video_path:
|
|
|
+ if not os.path.exists(video_path) or os.path.getsize(video_path) == 0:
|
|
|
+ in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
|
|
|
logger.error(f"[+] {url}下载失败")
|
|
|
AliyunLogger.logging(data["name"],"效率工具", data["tag_transport_channel"], data["video_url"],
|
|
|
- "视频下载失败", "3002", str(data))
|
|
|
+ "视频下载失败等待重新处理", "3002", str(data))
|
|
|
text = (
|
|
|
f"**负责人**: {data['name']}\n"
|
|
|
f"**内容**: {data}\n"
|
|
|
- f"**失败信息**: 视频下载失败\n"
|
|
|
+ f"**失败信息**: 视频下载失败等待重新处理,视频链接{url}\n"
|
|
|
)
|
|
|
Feishu.finish_bot(text,
|
|
|
"https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
|
|
@@ -188,6 +185,7 @@ class CarryViode:
|
|
|
|
|
|
|
|
|
elif data["transform_rule"] == "仅改造":
|
|
|
+ video_path = FFmpeg.video_640(video_path, file_path)
|
|
|
if data["video_clipping"]: # 判断是否需要裁剪
|
|
|
video_path = FFmpeg.video_crop(video_path, file_path)
|
|
|
if data["video_clipping_time"]: # 判断是否需要指定视频时长
|
|
@@ -223,7 +221,7 @@ class CarryViode:
|
|
|
logger.info(f"[+] {REDIS_NAME}的{data}数据片尾获取成功")
|
|
|
pw_srt = TTS.getSrt(pw_url)
|
|
|
pw_mp3_path = TTS.download_mp3(pw_url, file_path)
|
|
|
- if not pw_mp3_path or not pw_mp3_path:
|
|
|
+ if not pw_mp3_path:
|
|
|
logger.error(f"[+] {REDIS_NAME}的{data}数据片尾音频下载失败")
|
|
|
AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
"改造失败,片尾音频下载失败", "3001", str(data))
|
|
@@ -238,7 +236,7 @@ class CarryViode:
|
|
|
return
|
|
|
logger.info(f"[+] {REDIS_NAME}的{data}数据片尾音频下载成功")
|
|
|
jpg_path = FFmpeg.video_png(video_path, file_path) # 生成视频最后一帧jpg
|
|
|
- if not jpg_path:
|
|
|
+ if not os.path.exists(jpg_path) or os.path.getsize(jpg_path) == 0:
|
|
|
logger.error(f"[+] {REDIS_NAME}的{data}数据片尾获取最后一帧失败")
|
|
|
AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
"改造失败,获取最后一帧失败", "3001", str(data))
|
|
@@ -253,7 +251,7 @@ class CarryViode:
|
|
|
return
|
|
|
logger.info(f"[+] {REDIS_NAME}的{data}数据片尾获取最后一帧成功")
|
|
|
pw_path = FFmpeg.pw_video(jpg_path, file_path, pw_mp3_path, pw_srt) # 生成片尾视频
|
|
|
- if not pw_path:
|
|
|
+ if not os.path.exists(pw_path) or os.path.getsize(pw_path) == 0:
|
|
|
logger.error(f"[+] {REDIS_NAME}的{data}数据片尾拼接失败")
|
|
|
AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
"改造失败,片尾拼接失败", "3001", str(data))
|
|
@@ -266,26 +264,10 @@ class CarryViode:
|
|
|
"https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
|
|
|
"【 搬运&改造效率工具失败通知 】")
|
|
|
return
|
|
|
- pw_video_list = [video_path, pw_path]
|
|
|
+ video_paths = [video_path, pw_path]
|
|
|
logger.info(f"[+] {REDIS_NAME}的{data}数据合并开始拼接")
|
|
|
- video_path = FFmpeg.concatenate_videos(pw_video_list, file_path) # 视频与片尾拼接到一起
|
|
|
- if not video_path:
|
|
|
- logger.error(f"[+] {REDIS_NAME}的{data}数据合并拼接失败")
|
|
|
- AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
- "改造失败,合并拼接失败", "3001", str(data))
|
|
|
- text = (
|
|
|
- f"**负责人**: {data['name']}\n"
|
|
|
- f"**内容**: {data}\n"
|
|
|
- f"**失败信息**: 视频合并拼接失败\n"
|
|
|
- )
|
|
|
- Feishu.finish_bot(text,
|
|
|
- "https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
|
|
|
- "【 搬运&改造效率工具失败通知 】")
|
|
|
- return
|
|
|
- logger.info(f"[+] {REDIS_NAME}的{data}数据合并拼接成功")
|
|
|
- if data["video_share"]:
|
|
|
- video_path = FFmpeg.single_video(video_path, file_path, data["video_share"])
|
|
|
- if not video_path:
|
|
|
+ video_path = FFmpeg.single_video(video_paths, file_path, data["video_share"])
|
|
|
+ if not os.path.exists(video_path) or os.path.getsize(video_path) == 0:
|
|
|
logger.error(f"[+] {REDIS_NAME}的{data}数据添加片中字幕失败")
|
|
|
AliyunLogger.logging(data["name"], "效率工具",data["tag_transport_channel"], data["video_url"],
|
|
|
"改造失败,添加片中字幕失败", "3001", str(data))
|
|
@@ -325,6 +307,12 @@ class CarryViode:
|
|
|
n_id_list = [n_ids]
|
|
|
pq_list = []
|
|
|
for n_id in n_id_list:
|
|
|
+ logger.info(f"[+] {url}开始处理标题")
|
|
|
+ if data["title_category"] == "AI标题" or data["trailer_share"] == "AI标题":
|
|
|
+ title = GPT4o.get_ai_title(
|
|
|
+ original_title if data["title_category"] == "原标题" else data["title_category"])
|
|
|
+ else:
|
|
|
+ title = original_title if data["title_category"] == "原标题" else data["title_category"]
|
|
|
code = PQ.insert_piaoquantv(oss_object_key, title, n_id)
|
|
|
if not code:
|
|
|
logger.error(f"[+] {REDIS_NAME}的{data}写入票圈后台失败")
|