123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554 |
- import html
- import json
- import os
- import random
- import re
- import time
- import uuid
- import requests
- from datetime import datetime
- from urllib.parse import urlparse, parse_qs
- from loguru import logger
- from common import Oss, Feishu, AliyunLogger, Material
- from common.download_video import DownLoad
- from common.ffmpeg import FFmpeg
- from common.gpt4o_mini_help import GPT4oMini
- from common.redis import in_carry_video_data
- from common.sql_help import sqlCollect
- from common.tag_video import Tag
- from common.tts_help import TTS
- from data_channel.piaoquan import PQ
- class CarryViode:
- def get_text_dy_video(self,url):
- max_retries = 3
- retry_count = 0
- while retry_count < max_retries:
- try:
- if "&vid=" in url:
- parsed_url = urlparse(url)
- params = parse_qs(parsed_url.query)
- video_id = params.get('vid', [None])[0]
- elif "?modal_id=" in url:
- parsed_url = urlparse(url)
- params = parse_qs(parsed_url.query)
- video_id = params.get('modal_id', [None])[0]
- else:
- headers = {
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;'
- 'q=0.8,application/signed-exchange;v=b3;q=0.7',
- 'Accept-Language': 'zh-CN,zh;q=0.9',
- 'Cache-Control': 'no-cache',
- 'Pragma': 'no-cache',
- 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) '
- 'Chrome/127.0.0.0 Safari/537.36',
- }
- response = requests.request(url=url, method='GET', headers=headers, allow_redirects=False, timeout=30)
- location = response.headers.get('Location', None)
- video_id = re.search(r'/video/(\d+)/?', location.split('?')[0] if location else url).group(1)
- url = "http://8.217.192.46:8889/crawler/dou_yin/detail"
- if not video_id or not video_id.strip():
- return None, None, None
- payload = json.dumps({
- "content_id": str(video_id)
- })
- headers = {
- 'Content-Type': 'application/json'
- }
- response = requests.request("POST", url, headers=headers, data=payload, timeout= 60)
- response = response.json()
- code = response["code"]
- if code == 0:
- data = response["data"]["data"]
- video_url = data["video_url_list"][0]["video_url"]
- original_title = data["title"]
- return video_url, original_title, video_id
- if code == 22002:
- if '抖音内容已被删除或无法访问' in response['msg']:
- return "作品不存在", None, None
- except Exception as e:
- retry_count += 1
- logger.error(f"[+] 抖音{url}获取视频链接失败,失败信息{e}")
- time.sleep(1)
- return None, None, None
- def get_text_ks_video(self,url):
- try:
- headers = {
- 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;'
- 'q=0.8,application/signed-exchange;v=b3;q=0.7',
- 'Accept-Language': 'zh-CN,zh;q=0.9',
- 'Cache-Control': 'no-cache',
- 'Pragma': 'no-cache',
- 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) '
- 'Chrome/127.0.0.0 Safari/537.36',
- }
- response = requests.request(url=url, method='GET', headers=headers, allow_redirects=False, timeout= 30)
- location = response.headers.get('Location', None)
- video_id = re.search(r'/(f|photo|short-video|long-video)/(.*)/?',
- location.split('?')[0] if location else url).group(2)
- url = "http://8.217.192.46:8889/crawler/kuai_shou/detail"
- if not video_id or not video_id.strip():
- return None, None, None
- payload = json.dumps({
- "content_id": str(video_id)
- })
- headers = {
- 'Content-Type': 'application/json'
- }
- time.sleep(random.uniform(10, 50))
- response = requests.request("POST", url, headers=headers, data=payload, timeout= 30)
- response = response.json()
- code = response["code"]
- if code == 0:
- data = response["data"]["data"]
- content_type = data['content_type']
- if content_type == 'note':
- return "note","note"
- video_url = data["video_url_list"][0]["video_url"]
- original_title = data["title"]
- return video_url, original_title, video_id
- elif code == 27006:
- if "作品不存在" in response['msg'] or "内容不存在" in response['msg'] or "私密作品" in response['msg']:
- return "作品不存在", None, None
- time.sleep(3)
- except Exception as e:
- logger.error(f"[+] 快手{url}获取视频链接失败,失败信息{e}")
- return None, None,None
- def insert_pq(self, REDIS_NAME, data, oss_object_key, title, tags, tag_transport_channel, channel_mark):
- logger.info(f"[+] {REDIS_NAME}的{data}开始写入票圈")
- n_ids = str(data["pq_ids"])
- if ',' in n_ids:
- n_id_list = n_ids.split(',')
- else:
- n_id_list = [n_ids]
- pq_list = []
- for n_id in n_id_list:
- code = PQ.insert_piaoquantv(oss_object_key, title, n_id)
- if not code:
- logger.error(f"[+] {REDIS_NAME}的{data}写入票圈后台失败")
- AliyunLogger.logging(data["name"], "效率工具", tag_transport_channel, data["video_url"],
- "改造失败,写入票圈后台失败", "3001", str(data))
- text = (
- f"**负责人**: {data['name']}\n"
- f"**内容**: {data}\n"
- f"**失败信息**: 视频写入票圈后台失败,视频ID{code}\n"
- )
- Feishu.finish_bot(text,
- "https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
- "【 搬运&改造效率工具失败通知 】")
- continue
- pq_list.append(code)
- logger.info(f"[+] {REDIS_NAME}的{data}写入票圈成功,返回视频id{code}")
- tag_status = Tag.video_tag(code, str(tags))
- if tag_status == 0:
- logger.info(f"[+] {REDIS_NAME}的{data}写入标签成功,后台视频ID为{code}")
- try:
- current_time = datetime.now()
- formatted_time = current_time.strftime("%Y-%m-%d %H:%M:%S")
- sqlCollect.insert_machine_making_data(data["name"], "搬运工具", tag_transport_channel,
- data["video_url"], data["video_url"], data["pq_ids"],
- data["title_category"],
- code,
- formatted_time, data["title_category"], oss_object_key)
- pq_url = f'https://admin.piaoquantv.com/cms/post-detail/{code}/detail' # 站内视频链接
- values = [
- [
- str(code),
- str(n_id),
- formatted_time,
- channel_mark,
- data["name"],
- data["pq_ids"],
- data["pq_label"],
- data["activate_data"],
- data["video_url"],
- data["title_category"],
- tag_transport_channel,
- data["tag_transport_scene"],
- data["tag_transport_keyword"],
- data["tag"],
- data["transform_rule"],
- data["video_share"],
- data["trailer_share"],
- data["trailer_share_audio"],
- data["video_clipping"],
- data["video_clipping_time"],
- data["title_transform"],
- pq_url
- ]
- ]
- name_to_sheet = {
- "范军": "276ffc",
- "鲁涛": "QqrKRY",
- "余海涛": "dTzUlI",
- "罗情": "8JPv9g",
- "刘诗雨": "HqwG0o",
- "王媛": "vtWvle",
- "周仙琴": "MWUqWt",
- "王雪珂": "xN1KrU",
- "信欣": "PtoeGT"
- }
- name = re.sub(r"\s+", "", data.get("name", ""))
- sheet = name_to_sheet.get(name)
- Feishu.insert_columns("R4dLsce8Jhz9oCtDMr9ccpFHnbI", sheet, "ROWS", 1, 2)
- time.sleep(0.5)
- Feishu.update_values("R4dLsce8Jhz9oCtDMr9ccpFHnbI", sheet, "A2:Z2", values)
- logger.info(f"[+] {REDIS_NAME}的{data}写入飞书成功")
- except Exception as e:
- logger.error(f"[+] {REDIS_NAME}的{data}写入飞书失败{e}")
- pass
- AliyunLogger.logging(data["name"], "效率工具", tag_transport_channel, data["video_url"],
- "改造成功", "1000", str(data), str(pq_list))
- return
- def main(self, data, REDIS_NAME, file_path):
- tag_transport_channel = None
- try:
- url = data['video_url']
- if "&vid=" in url or "?modal_id=" in url:
- host = urlparse(url).netloc
- else:
- msg = html.unescape(url).split('?')[0]
- pattern = re.search(r'https?://[^\s<>"\'\u4e00-\u9fff]+', msg)
- if not pattern:
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- return
- url = pattern.group()
- host = urlparse(url).netloc
- if host in ['v.douyin.com', 'www.douyin.com', 'www.iesdouyin.com']:
- tag_transport_channel = "抖音"
- logger.info(f"[+] {url}开始获取抖音视频链接")
- url, original_title, video_id = self.get_text_dy_video(url=url)
- elif host in ['v.kuaishou.com', 'www.kuaishou.com', 'v.m.chenzhongtech.com', 'creater.eozatvmq.com']:
- tag_transport_channel = "快手"
- logger.info(f"[+] {url}开始获取快手视频链接")
- url, original_title, video_id = self.get_text_ks_video(url=url)
- else:
- AliyunLogger.logging(data["name"], "效率工具", "", data["video_url"], "扫描到一条视频",
- "2001", str(data))
- logger.error(f"[+] {url}该链接不是抖/快 不做处理")
- AliyunLogger.logging(data["name"], "效率工具",tag_transport_channel, data["video_url"],
- "不是抖/快不做处理", "1001", 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
- if url == "作品不存在":
- 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
- except Exception as e:
- logger.info(f"[+] 获取视频链接异常{e}")
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- return
- AliyunLogger.logging(data["name"],"效率工具", tag_transport_channel, data["video_url"], "扫描到一条视频", "2001", str(data))
- AliyunLogger.logging(data["name"], "效率工具",tag_transport_channel, data["video_url"], "符合规则等待改造", "2004", str(data))
- if not url:
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.info(f"[+] {url}没有获取到视频链接,等待重新处理")
- AliyunLogger.logging(data["name"], "效率工具",tag_transport_channel, data["video_url"],
- "没有获取到视频链接,等待重新处理", "1002", 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
- if url == "note":
- logger.info(f"[+] {url}是图文不做处理")
- AliyunLogger.logging(data["name"], "效率工具", tag_transport_channel, data["video_url"],
- "是图文不做处理", "1002", 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"[+] {url}开始下载视频")
- video_path = DownLoad.download_video(url, file_path, tag_transport_channel, video_id)
- # video_path = Oss.download_video_oss(url, file_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"],"效率工具", tag_transport_channel, data["video_url"],
- "视频下载失败等待重新处理", "3002", str(data))
- text = (
- f"**负责人**: {data['name']}\n"
- f"**内容**: {data}\n"
- f"**失败信息**: 视频下载失败等待重新处理,视频链接{url}\n"
- )
- Feishu.finish_bot(text,
- "https://open.feishu.cn/open-apis/bot/v2/hook/65bc5463-dee9-46d0-bc2d-ec6c49a8f3cd",
- "【 搬运&改造效率工具失败通知 】")
- return
- logger.info(f"[+] {url}开始视频下载成功")
- logger.info(f"[+] {url}开始处理标题")
- if data["title_category"] == "AI标题" or data["trailer_share"] == "AI标题":
- title = GPT4oMini.get_ai_mini_title(
- original_title if data["title_category"] == "AI标题" else data["title_category"])
- else:
- title = original_title if data["title_category"] == "原标题" else data["title_category"]
- if tag_transport_channel == "抖音":
- if "复制打开抖音" in data['video_url']:
- channel_mark = "APP"
- else:
- channel_mark = "PC"
- else:
- if "https://www.kuaishou.com/f" in data['video_url']:
- channel_mark = "PC"
- else:
- channel_mark = "APP"
- if data["transform_rule"] == '否'or data["transform_rule"] == "是":
- logger.info(f"[+] {REDIS_NAME}的{data}数据开始发送oss")
- oss_object_key = Oss.stitching_sync_upload_oss(video_path, str(uuid.uuid4())) # 视频发送OSS
- status = oss_object_key.get("status")
- if status != 200:
- logger.error(f"[+] {REDIS_NAME}的{data}数据发送oss失败")
- AliyunLogger.logging(data["name"], "效率工具",tag_transport_channel, data["video_url"],
- "改造失败,发送oss失败", "3001", str(data))
- text = (
- f"**负责人**: {data['name']}\n"
- f"**内容**: {data}\n"
- f"**失败信息**: 视频发送OSS失败\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}数据发送oss成功")
- oss_object_key = oss_object_key.get("oss_object_key")
- tags = ','.join(filter(None, [
- data['pq_label'],
- channel_mark,
- tag_transport_channel,
- data['tag_transport_scene'],
- data['tag_transport_keyword'],
- "搬运工具",
- data['tag']
- ]))
- self.insert_pq(REDIS_NAME, data, oss_object_key, title, tags, tag_transport_channel, channel_mark)
- if data["transform_rule"] == "仅改造" or data["transform_rule"] == "是":
- try:
- width, height = FFmpeg.get_w_h_size(video_path)
- if width < height: # 判断是否需要修改为竖屏
- video_path = FFmpeg.update_video_h_w(video_path, file_path)
- logger.info(f"[+] {REDIS_NAME}的{data}视频更改分辨率处理")
- video_path = FFmpeg.video_640(video_path, file_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"[+] {REDIS_NAME}的{data}视频更改分辨率失败")
- AliyunLogger.logging(data["name"], "效率工具", 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_clipping"]: # 判断是否需要裁剪
- video_path = FFmpeg.video_crop(video_path, file_path)
- if data["video_clipping_time"]: # 判断是否需要指定视频时长
- video_path = FFmpeg.video_ggduration(video_path, file_path, data["video_clipping_time"])
- if data['trailer_share']:
- if data['trailer_share'] == "AI片尾引导" or data['trailer_share'] == "AI片尾引导1" :
- prompt = Material.get_propmt_data(data['trailer_share'])
- pw_srt_text = GPT4oMini.get_ai_mini_pw(title, prompt)
- else:
- pw_srt_text = str(data['trailer_share'])
- voice = data['trailer_share_audio']
- if voice:
- if ',' in voice:
- voices = voice.split(',')
- else:
- voices = [voice]
- voice = random.choice(voices)
- else:
- voice = "zhifeng_emo"
- pw_url = TTS.get_pw_zm(pw_srt_text, voice)
- if not pw_url:
- logger.error(f"[+] {REDIS_NAME}的{data}数据片尾获取失败")
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- AliyunLogger.logging(data["name"],"效率工具", 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}数据片尾获取成功")
- pw_srt = TTS.getSrt(pw_url)
- if not pw_srt:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] {REDIS_NAME}的{data}数据片尾音频srt获取失败")
- AliyunLogger.logging(data["name"], "效率工具", 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
- pw_mp3_path = TTS.download_mp3(pw_url, file_path)
- if not pw_mp3_path:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] {REDIS_NAME}的{data}数据片尾音频下载失败")
- AliyunLogger.logging(data["name"], "效率工具",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}数据片尾音频下载成功")
- jpg_path = FFmpeg.video_png(video_path, file_path) # 生成视频最后一帧jpg
- if not os.path.exists(jpg_path) or os.path.getsize(jpg_path) == 0:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] {REDIS_NAME}的{data}数据片尾获取最后一帧失败")
- AliyunLogger.logging(data["name"], "效率工具",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}数据片尾获取最后一帧成功")
- pw_path = FFmpeg.pw_video(jpg_path, file_path, pw_mp3_path, pw_srt) # 生成片尾视频
- if not os.path.exists(pw_path) or os.path.getsize(pw_path) == 0:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] {REDIS_NAME}的{data}数据片尾拼接失败")
- AliyunLogger.logging(data["name"], "效率工具",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}数据合并开始拼接")
- video_path = FFmpeg.h_b_video(video_path, pw_path, file_path)
- video_path = FFmpeg.single_video(video_path, file_path, data["video_share"])
- if not os.path.exists(video_path) or os.path.getsize(video_path) == 0:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] {REDIS_NAME}的{data}数据添加片中字幕失败")
- AliyunLogger.logging(data["name"], "效率工具",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}数据添加片中字幕成功")
- logger.info(f"[+] {REDIS_NAME}的{data}数据开始发送oss")
- oss_object_key = Oss.stitching_sync_upload_oss(video_path, str(uuid.uuid4())) # 视频发送OSS
- status = oss_object_key.get("status")
- if status != 200:
- logger.error(f"[+] {REDIS_NAME}的{data}数据发送oss失败")
- AliyunLogger.logging(data["name"],"效率工具", tag_transport_channel, data["video_url"],
- "改造失败,发送oss失败", "3001", str(data))
- text = (
- f"**负责人**: {data['name']}\n"
- f"**内容**: {data}\n"
- f"**失败信息**: 视频发送OSS失败\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}数据发送oss成功")
- oss_object_key = oss_object_key.get("oss_object_key")
- tags = ','.join(filter(None, [
- data['pq_label'],
- channel_mark,
- tag_transport_channel,
- data['tag_transport_scene'],
- data['tag_transport_keyword'],
- "搬运改造",
- data['tag']
- ]))
- self.insert_pq(REDIS_NAME, data, oss_object_key, title, tags, tag_transport_channel, channel_mark)
- return
- except Exception as e:
- data["transform_rule"] = "仅改造"
- in_carry_video_data(REDIS_NAME, json.dumps(data, ensure_ascii=False, indent=4))
- logger.error(f"[+] 视频改造失败{e}")
- 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
- return
|