material.py 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. # -*- coding: utf-8 -*-
  2. # @Time: 2023/12/26
  3. import os
  4. import random
  5. import sys
  6. sys.path.append(os.getcwd())
  7. from common.db import MysqlHelper
  8. from common.feishu import Feishu
  9. class Material():
  10. # 获取视频链接 存入数据库
  11. @classmethod
  12. def insert_user(cls):
  13. # 获取抖音视频链接
  14. douyin = Feishu.get_values_batch("prod", "succinct", "iYbVis")
  15. # 提取账号昵称和账号主页链接
  16. channel = '抖音'
  17. for row in douyin[2:]:
  18. platform = row[0]
  19. if platform == channel:
  20. account_name = row[2]
  21. account_link = row[3]
  22. user_id = account_link.split("user/")[1]
  23. insert_sql = f"""INSERT INTO video_user_id (name, user_id, channel) values ('{account_name}', '{user_id}', '{channel}')"""
  24. MysqlHelper.update_values(
  25. sql=insert_sql,
  26. env="prod",
  27. machine="",
  28. )
  29. # 随机获取标题
  30. @classmethod
  31. def get_title(cls):
  32. title = Feishu.get_values_batch("prod", "succinct", "meGnsz")
  33. random_item = random.choice(title)
  34. cleaned_item = random_item[0].strip("[]'")
  35. return cleaned_item
  36. # 获取所有音频
  37. @classmethod
  38. def get_audio(cls):
  39. audio = Feishu.get_values_batch("prod", "succinct", "zucQUM")
  40. list = []
  41. for row in audio[1:]:
  42. account_name = row[0]
  43. text = row[2]
  44. number = {"audio_id": account_name,"text": text}
  45. list.append(number)
  46. list = random.choice(list)
  47. audio_id = list['audio_id']
  48. srt = list['text']
  49. return audio_id, srt
  50. # 获取抖音 cookie
  51. @classmethod
  52. def get_douyin_cookie(cls):
  53. douyin_token = Feishu.get_values_batch("prod", "succinct", "OpE35G")
  54. for item in douyin_token:
  55. if item[0] == '抖音':
  56. return item[1]
  57. @classmethod
  58. def get_houtai_cookie(cls):
  59. douyin_token = Feishu.get_values_batch("prod", "succinct", "OpE35G")
  60. for item in douyin_token:
  61. if item[0] == '管理后台':
  62. return item[1]
  63. # 获取音频类型
  64. @classmethod
  65. def get_audio_type(cls):
  66. audio_type = [{"audio": "音画美文--美文类", "type": "6VXm7q"}, {"audio": "音画美文--通用类", "type": "aSNFl8"},
  67. {"audio": "口播--美文类", "type": "Sed8gy"}]
  68. audio_type = random.choice(audio_type)
  69. type_audio = audio_type['audio']
  70. type = audio_type['type']
  71. audio_type = Feishu.get_values_batch("prod", "succinct", type)
  72. list = []
  73. title_list = []
  74. if type_audio == "口播--美文类":
  75. for row in audio_type[1:]:
  76. audio_id = row[2]
  77. text = row[3]
  78. title = row[4]
  79. number = {"audio_id": audio_id, "text": text}
  80. list.append(number)
  81. title_list.append(title)
  82. list = random.choice(list)
  83. audio_id = list['audio_id']
  84. srt = list['text']
  85. return audio_id, srt, title_list, type_audio
  86. else:
  87. for row in audio_type[1:]:
  88. audio_id = row[0]
  89. text = row[1]
  90. title = row[2]
  91. number = {"audio_id": audio_id, "text": text}
  92. list.append(number)
  93. title_list.append(title)
  94. list = random.choice(list)
  95. audio_id = list['audio_id']
  96. srt = list['text']
  97. return audio_id, srt, title_list, type_audio