download_play.py 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. # -*- coding: utf-8 -*-
  2. # @Author: wangkun
  3. # @Time: 2022/4/18
  4. """
  5. 下载并上传:播放量视频
  6. """
  7. import os
  8. import sys
  9. import time
  10. sys.path.append(os.getcwd())
  11. from main.common import Common
  12. from main.get_feeds import get_feeds
  13. from main.publish import Publish
  14. from main.feishu_lib import Feishu
  15. class DownloadPlay:
  16. # 下载规则
  17. @staticmethod
  18. def play_rule(play_width, play_height, play_duration, play_play_cnt):
  19. """
  20. 1.分辨率,宽或者高 >= 720 or ==0
  21. 2.600s >= 时长 >= 60s
  22. 3.视频播放量 >= 150000
  23. """
  24. if int(play_width) >= 720 or int(play_height) >= 720 or play_width == "0" or play_height == "0":
  25. if 600 >= int(play_duration) >= 60:
  26. if int(play_play_cnt) >= 150000:
  27. return True
  28. else:
  29. return False
  30. else:
  31. return False
  32. else:
  33. return False
  34. @classmethod
  35. def download_play_video(cls, env):
  36. """
  37. 下载播放量视频
  38. 测试环境:env == dev
  39. 正式环境:env == prod
  40. """
  41. try:
  42. if len(Feishu.get_values_batch("SdCHOM")) == 1:
  43. pass
  44. else:
  45. for i in range(len(Feishu.get_values_batch("SdCHOM"))):
  46. time.sleep(1)
  47. try:
  48. download_video_id = Feishu.get_values_batch("SdCHOM")[i+1][1]
  49. download_video_play_cnt = Feishu.get_values_batch("SdCHOM")[i+1][2]
  50. download_video_title = Feishu.get_values_batch("SdCHOM")[i+1][3]
  51. download_video_duration = Feishu.get_values_batch("SdCHOM")[i+1][4]
  52. download_video_comment_cnt = Feishu.get_values_batch("SdCHOM")[i+1][5]
  53. download_video_like_cnt = Feishu.get_values_batch("SdCHOM")[i+1][6]
  54. download_video_share_cnt = Feishu.get_values_batch("SdCHOM")[i+1][7]
  55. download_video_resolution = Feishu.get_values_batch("SdCHOM")[i+1][8]
  56. download_video_width = download_video_resolution.split("*")[0]
  57. download_video_height = download_video_resolution.split("*")[-1]
  58. download_video_send_time = Feishu.get_values_batch("SdCHOM")[i+1][9]
  59. download_user_name = Feishu.get_values_batch("SdCHOM")[i+1][10]
  60. download_head_url = Feishu.get_values_batch("SdCHOM")[i+1][11]
  61. download_cover_url = Feishu.get_values_batch("SdCHOM")[i+1][12]
  62. download_video_url = Feishu.get_values_batch("SdCHOM")[i+1][13]
  63. download_video_session = Feishu.get_values_batch("SdCHOM")[i+1][14]
  64. if download_video_id not in [j for i in Feishu.get_values_batch("20ce0c") for j in i]\
  65. and cls.play_rule(download_video_width, download_video_height,
  66. download_video_duration, download_video_play_cnt) is True:
  67. Common.logger().info("开始下载视频:{}", download_video_title)
  68. # 下载封面
  69. Common.download_method(text="cover", d_name=download_video_title, d_url=download_cover_url)
  70. # 下载视频
  71. Common.download_method(text="video", d_name=download_video_title, d_url=download_video_url)
  72. # 保存视频信息至 "./videos/{download_video_title}/info.txt"
  73. with open(r"./videos/" + download_video_title
  74. + "/" + "info.txt", "a", encoding="utf8") as f_a:
  75. f_a.write(str(download_video_id) + "\n" +
  76. str(download_video_title) + "\n" +
  77. str(download_video_duration) + "\n" +
  78. str(download_video_play_cnt) + "\n" +
  79. str(download_video_comment_cnt) + "\n" +
  80. str(download_video_like_cnt) + "\n" +
  81. str(download_video_share_cnt) + "\n" +
  82. str(download_video_resolution) + "\n" +
  83. str(download_video_send_time) + "\n" +
  84. str(download_user_name) + "\n" +
  85. str(download_head_url) + "\n" +
  86. str(download_video_url) + "\n" +
  87. str(download_cover_url) + "\n" +
  88. str(download_video_session))
  89. Common.logger().info("==========视频信息已保存至info.txt==========")
  90. # 上传视频
  91. Common.logger().info("开始上传视频:{}", download_video_title)
  92. Publish.upload_and_publish(env, "play")
  93. # 保存视频 ID 到云文档:https://w42nne6hzg.feishu.cn/sheets/shtcngRPoDYAi24x52j2nDuHMih?sheet=20ce0c
  94. Common.logger().info("保存视频ID至云文档:{}", download_video_title)
  95. # 看一看+ ,视频ID工作表,插入首行
  96. Feishu.insert_columns("20ce0c")
  97. # 看一看+ ,视频ID工作表,首行写入数据
  98. upload_time = int(time.time())
  99. Feishu.update_values("20ce0c",
  100. str(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(upload_time))),
  101. str(download_video_id),
  102. str(download_video_play_cnt),
  103. str(download_video_title),
  104. str(download_video_duration),
  105. str(download_video_comment_cnt),
  106. str(download_video_like_cnt),
  107. str(download_video_share_cnt),
  108. str(download_video_resolution),
  109. str(time.strftime("%Y-%m-%d %H:%M:%S",
  110. time.localtime(
  111. int(download_video_send_time)))),
  112. str(download_user_name),
  113. str(download_head_url),
  114. str(download_cover_url),
  115. str(download_video_url),
  116. str(download_video_session))
  117. # 从云文档删除该视频信息:https://w42nne6hzg.feishu.cn/sheets/shtcngRPoDYAi24x52j2nDuHMih?sheet=SdCHOM
  118. Common.logger().info("从云文档删除该视频信息:{}", download_video_title)
  119. # 删除行或列,可选 ROWS、COLUMNS
  120. Feishu.dimension_range("SdCHOM", "ROWS", i + 2, i + 2)
  121. else:
  122. # 从云文档删除该视频信息:https://w42nne6hzg.feishu.cn/sheets/shtcngRPoDYAi24x52j2nDuHMih?sheet=SdCHOM
  123. Common.logger().info("该视频不满足下载规则,删除在云文档中的信息:{}", download_video_title)
  124. # 删除行或列,可选 ROWS、COLUMNS
  125. Feishu.dimension_range("SdCHOM", "ROWS", i + 2, i + 2)
  126. except Exception as e:
  127. Common.logger().error("视频 info 异常,删除该视频信息", e)
  128. # 删除行或列,可选 ROWS、COLUMNS
  129. Feishu.dimension_range("SdCHOM", "ROWS", i + 2, i + 2)
  130. cls.download_play_video("prod")
  131. except Exception as e:
  132. Common.logger().error(e)
  133. if __name__ == "__main__":
  134. download_play = DownloadPlay()
  135. get_feeds()
  136. download_play.download_play_video("dev")