123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249 |
- """
- @author: luojunhui
- @description: GetOffVideos Daily
- """
- import json
- import time
- import requests
- import schedule
- from tqdm import tqdm
- from applications import PQMySQL, Functions, log
- from applications.decoratorApi import retryOnTimeout
- @retryOnTimeout()
- def bot(account_list):
- """
- 机器人
- """
- url = "https://open.feishu.cn/open-apis/bot/v2/hook/b44333f2-16c0-4cb1-af01-d135f8704410"
- headers = {"Content-Type": "application/json"}
- payload = {
- "msg_type": "interactive",
- "card": {
- "elements": [
- {
- "tag": "div",
- "text": {
- "content": "存在视频下架失败<at id=all></at>\n",
- "tag": "lark_md",
- },
- },
- {
- "tag": "div",
- "text": {
- "content": json.dumps(
- account_list, ensure_ascii=False, indent=4
- ),
- "tag": "lark_md",
- },
- },
- ],
- "header": {"title": {"content": "【重点关注】", "tag": "plain_text"}},
- },
- }
- requests.request("POST", url=url, headers=headers, data=json.dumps(payload), timeout=10)
- class AutoGetOffVideos(object):
- """
- 自动下架视频
- """
- pqMysql = PQMySQL()
- @classmethod
- def getLongArticlesVideos(cls, time_stamp):
- """
- 获取待下架的视频
- :return:
- """
- select_sql = f"""
- SELECT video_id
- FROM get_off_videos
- WHERE video_status = 1 and publish_time < {time_stamp};
- """
- result = cls.pqMysql.select(sql=select_sql)
- log(
- task="getOffVideosDaily",
- function="getLongArticlesVideos",
- message="查找到视频 id_list,一共{}条视频".format(len(result))
- )
- return result
- @classmethod
- def updateVideoIdStatus(cls, video_id):
- """
- 修改数据库内视频状态
- :param video_id:
- :return:
- """
- time_stamp = int(time.time())
- select_sql = f"""
- UPDATE get_off_videos
- SET video_status = 0, get_off_time = {time_stamp}
- WHERE video_id = %s;
- """
- try:
- cls.pqMysql.update(
- sql=select_sql,
- params=video_id
- )
- log(
- task="getOffVideosDaily",
- function="updateVideoIdStatus",
- message="成功修改视频状态",
- data={"video_id": video_id}
- )
- except Exception as e:
- log(
- task="getOffVideosDaily",
- function="updateVideoIdStatus",
- message="修改视频状态失败--- 推测 sql 问题,报错信息:{}".format(e),
- status="fail"
- )
- @classmethod
- def changeVideoIdStatus(cls, video_id):
- """
- 修改视频规则
- :return:
- """
- url = "https://admin.piaoquantv.com/manager/video/audit/v2/updateAuditStatus"
- payload = "videoId={}&auditStatus=2&updateReasonJson=&rejectReasonJson=%5B%7B%22reason%22%3A%22%E9%95%BF%E6%96%87%E8%87%AA%E5%8A%A8%E4%B8%8B%E6%9E%B6%22%2C%22reasonId%22%3A-1%7D%5D&adminUid=206".format(
- video_id)
- headers = {
- 'accept': 'application/json',
- 'accept-language': 'en,zh;q=0.9,zh-CN;q=0.8',
- 'content-type': 'application/x-www-form-urlencoded;charset=UTF-8',
- 'cookie': 'SESSION=NTljNTg2YjktMTU0MC00YWQ5LWE4ZTktNDFhODY0NzM3NTcx',
- 'origin': 'https://admin.piaoquantv.com',
- 'priority': 'u=1, i',
- 'sec-ch-ua': '"Not/A)Brand";v="8", "Chromium";v="126", "Google Chrome";v="126"',
- 'sec-ch-ua-mobile': '?0',
- 'sec-ch-ua-platform': '"macOS"',
- 'sec-fetch-dest': 'empty',
- 'sec-fetch-mode': 'cors',
- 'sec-fetch-site': 'same-origin',
- 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36'
- }
- response = requests.request(
- "POST",
- url,
- headers=headers,
- data=payload,
- timeout=10
- )
- if response.status_code == 200:
- result = response.json()
- if result.get("code", None) == 0:
- cls.updateVideoIdStatus(video_id=video_id)
- else:
- log(
- task="getOffVideosDaily",
- function="changeVideoIdStatus",
- message="请求票圈修改状态异常---video_id = {}".format(video_id),
- data=result
- )
- else:
- log(
- task="getOffVideosDaily",
- function="changeVideoIdStatus",
- status="fail",
- message="请求票圈修改状态异常,状态码非 200 ---video_id = {}".format(video_id),
- )
- @classmethod
- def task1(cls):
- """
- 已经请求超过3天的视频全部下架
- :return:
- """
- now_stamp = int(time.time())
- three_days_before = now_stamp - 3 * 24 * 60 * 60
- video_set = cls.getLongArticlesVideos(time_stamp=three_days_before)
- vid_list = [i[0] for i in video_set]
- for video_id in tqdm(vid_list):
- try:
- cls.changeVideoIdStatus(video_id=video_id)
- except Exception as e:
- log(
- task="getOffVideosDaily",
- function="task1",
- status="fail",
- message="task1下架单个视频失败,video_id={}, 报错信息={}".format(video_id, e),
- )
- @classmethod
- def task2(cls):
- """
- 校验 3 天前发布的视频是否已经下架
- :return:
- """
- three_days_ago = int(time.time()) - 3 * 24 * 3600
- sql = f"""
- SELECT video_id
- FROM get_off_videos
- WHERE publish_time < {three_days_ago} and video_status = 1;
- """
- vid_tuple = cls.pqMysql.select(sql)
- if vid_tuple:
- vid_list = [i[0] for i in vid_tuple]
- for vid in vid_list:
- try:
- cls.changeVideoIdStatus(video_id=vid)
- except Exception as e:
- log(
- task="getOffVideosDaily",
- function="task2",
- status="fail",
- message="task2下架单个视频失败,video_id={}, 报错信息={}".format(vid, e),
- )
- time.sleep(10)
- vid_tuple2 = cls.pqMysql.select(sql)
- if vid_tuple2:
- vid_list2 = [i[0] for i in vid_tuple2]
- bot(vid_list2)
- else:
- return
- else:
- return
- def getOffJob():
- """
- 下架任务
- :return:
- """
- AGV = AutoGetOffVideos()
- AGV.task1()
- def checkJob():
- """
- 校验 3 天前发布的视频是否已经被下架
- :return:
- """
- AGV = AutoGetOffVideos()
- AGV.task2()
- if __name__ == '__main__':
- getOffJob()
- schedule.every().day.at("09:30").do(Functions().job_with_thread, getOffJob)
- schedule.every().day.at("10:30").do(Functions().job_with_thread, checkJob)
- schedule.every().day.at("14:30").do(Functions().job_with_thread, getOffJob)
- schedule.every().day.at("15:00").do(Functions().job_with_thread, checkJob)
- while True:
- schedule.run_pending()
- time.sleep(1)
- log(
- task="getOffVideos",
- function="main",
- message="自动下架视频任务正常执行"
- )
|