piaoquan_utils.py 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. import random
  2. import time
  3. import json
  4. import requests
  5. from urllib.parse import urlencode
  6. from common import Common
  7. from common.sql_help import sqlCollect
  8. class PQ:
  9. """
  10. 获取视频链接
  11. """
  12. @classmethod
  13. def get_audio_url(cls, task_mark, user_id, title, mark):
  14. url = f"https://admin.piaoquantv.com/manager/video/detail/{user_id}"
  15. payload = {}
  16. headers = {
  17. 'authority': 'admin.piaoquantv.com',
  18. 'accept': 'application/json, text/plain, */*',
  19. 'accept-language': 'zh-CN,zh;q=0.9',
  20. 'cache-control': 'no-cache',
  21. 'cookie': 'SESSION=YjU3MzgwNTMtM2QyYi00YjljLWI3YWUtZTBjNWYwMGQzYWNl',
  22. 'pragma': 'no-cache',
  23. 'referer': f'https://admin.piaoquantv.com/cms/post-detail/{user_id}/detail',
  24. 'sec-ch-ua': '"Not_A Brand";v="8", "Chromium";v="120", "Google Chrome";v="120"',
  25. 'sec-ch-ua-mobile': '?0',
  26. 'sec-ch-ua-platform': '"macOS"',
  27. 'sec-fetch-dest': 'empty',
  28. 'sec-fetch-mode': 'cors',
  29. 'sec-fetch-site': 'same-origin',
  30. 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36'
  31. }
  32. response = requests.request("GET", url, headers=headers, data=payload)
  33. data = response.json()
  34. try:
  35. list = []
  36. video_id = data["content"]["id"]
  37. if mark:
  38. status = sqlCollect.is_used(task_mark, video_id, mark)
  39. else:
  40. status = True
  41. if status:
  42. if title == '' or title == None:
  43. new_title = data["content"]["title"]
  44. else:
  45. if '/' in title:
  46. titles = title.split('/')
  47. else:
  48. titles = [title]
  49. new_title = random.choice(titles)
  50. video_url = data["content"]["transedVideoPath"]
  51. cover = data["content"]["coverImgPath"]
  52. all_data = {"video_id": video_id, "title": new_title, "cover": cover, "video_url": video_url}
  53. list.append(all_data)
  54. return list
  55. return list
  56. except Exception as e:
  57. Common.logger("video").warning(f"获取视频链接失败:{e}\n")
  58. return ""
  59. """
  60. 获取用户下的所有视频
  61. """
  62. @classmethod
  63. def get_user_url(cls, task_mark, user_id, number, title, mark):
  64. url = f"https://admin.piaoquantv.com/manager/video/page?uid={user_id}&pageNum=1&pageSize=100"
  65. payload = {}
  66. headers = {
  67. 'accept': 'application/json, text/plain, */*',
  68. 'cookie': 'SESSION=NjRmMGVjNTAtNzJiNi00ODE0LThjYzQtYmZiNTJhMDNiZTcz',
  69. 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'
  70. }
  71. response = requests.request("GET", url, headers=headers, data=payload)
  72. data = response.json()
  73. try:
  74. content = data["content"]["objs"]
  75. list = []
  76. for url in content:
  77. video_id = url["id"]
  78. status = sqlCollect.is_used(task_mark, video_id, mark)
  79. if status:
  80. if title == '' or title == None:
  81. new_title = url["title"]
  82. else:
  83. if '/' in title:
  84. titles = title.split('/')
  85. else:
  86. titles = [title]
  87. new_title = random.choice(titles)
  88. cover = url["coverImgPath"]
  89. video_url = url["transedVideoPath"]
  90. all_data = {"video_id": video_id, "title": new_title, "cover": cover, "video_url": video_url}
  91. list.append(all_data)
  92. if len(list) == int(number):
  93. Common.logger("log").info(f"获取视频总数:{len(list)}\n")
  94. return list
  95. Common.logger("log").info(f"获取视频总数:{len(list)}\n")
  96. return list
  97. except Exception as e:
  98. Common.logger("log").warning(f"获取音频视频链接失败:{e}\n")
  99. return ""
  100. """
  101. 获取封面
  102. """
  103. @classmethod
  104. def get_cover(cls, uid):
  105. time.sleep(1)
  106. url = "https://admin.piaoquantv.com/manager/video/multiCover/listV2"
  107. payload = json.dumps({
  108. "videoId": uid,
  109. "range": "2h"
  110. })
  111. headers = {
  112. 'accept': 'application/json',
  113. 'accept-language': 'zh-CN,zh;q=0.9',
  114. 'cache-control': 'no-cache',
  115. 'content-type': 'application/json',
  116. 'cookie': 'SESSION=YjU3MzgwNTMtM2QyYi00YjljLWI3YWUtZTBjNWYwMGQzYWNl',
  117. 'origin': 'https://admin.piaoquantv.com',
  118. 'pragma': 'no-cache',
  119. 'priority': 'u=1, i',
  120. 'sec-ch-ua': '"Chromium";v="124", "Google Chrome";v="124", "Not-A.Brand";v="99"',
  121. 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'
  122. }
  123. response = requests.request("POST", url, headers=headers, data=payload)
  124. data = response.json()
  125. content = data["content"]
  126. if len(content) == 1:
  127. return content[0]["coverUrl"]
  128. max_share_count = 0
  129. selected_cover_url = ""
  130. for item in content:
  131. share_count = item.get("shareWeight")
  132. if share_count is not None and share_count > max_share_count:
  133. max_share_count = share_count
  134. selected_cover_url = item["coverUrl"]
  135. elif share_count == max_share_count and item["createUser"] == "用户":
  136. selected_cover_url = item["coverUrl"]
  137. return selected_cover_url
  138. """
  139. 获取标题
  140. """
  141. @classmethod
  142. def get_title(cls, uid):
  143. url = "https://admin.piaoquantv.com/manager/video/multiTitleV2/listV2"
  144. payload = json.dumps({
  145. "videoId": uid,
  146. "range": "4h"
  147. })
  148. headers = {
  149. 'accept': 'application/json',
  150. 'accept-language': 'zh-CN,zh;q=0.9',
  151. 'cache-control': 'no-cache',
  152. 'content-type': 'application/json',
  153. 'cookie': 'SESSION=YjU3MzgwNTMtM2QyYi00YjljLWI3YWUtZTBjNWYwMGQzYWNl',
  154. 'origin': 'https://admin.piaoquantv.com',
  155. 'pragma': 'no-cache',
  156. 'priority': 'u=1, i',
  157. 'sec-ch-ua': '"Chromium";v="124", "Google Chrome";v="124", "Not-A.Brand";v="99"',
  158. 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'
  159. }
  160. response = requests.request("POST", url, headers=headers, data=payload)
  161. data = response.json()
  162. content = data["content"]
  163. if len(content) == 1:
  164. return content[0]["title"]
  165. max_share_count = 0
  166. selected_title = ""
  167. for item in content:
  168. share_count = item.get("shareWeight")
  169. if share_count is not None and share_count > max_share_count:
  170. max_share_count = share_count
  171. selected_title = item["title"]
  172. elif share_count == max_share_count and item["createUser"] == "用户":
  173. selected_title = item["title"]
  174. return selected_title
  175. """
  176. 新生成视频上传到对应账号下
  177. """
  178. @classmethod
  179. def insert_piaoquantv(cls, new_video_path, new_title, cover, n_id):
  180. url = "https://vlogapi.piaoquantv.com/longvideoapi/crawler/video/send"
  181. headers = {
  182. 'User-Agent': 'PQSpeed/486 CFNetwork/1410.1 Darwin/22.6.0',
  183. 'cookie': 'JSESSIONID=4DEA2B5173BB9A9E82DB772C0ACDBC9F; JSESSIONID=D02C334150025222A0B824A98B539B78',
  184. 'referer': 'http://appspeed.piaoquantv.com',
  185. 'token': '524a8bc871dbb0f4d4717895083172ab37c02d2f',
  186. 'accept-language': 'zh-CN,zh-Hans;q=0.9',
  187. 'Content-Type': 'application/x-www-form-urlencoded'
  188. }
  189. payload = {
  190. 'coverImgPath': cover,
  191. 'deviceToken': '9ef064f2f7869b3fd67d6141f8a899175dddc91240971172f1f2a662ef891408',
  192. 'fileExtensions': 'MP4',
  193. 'loginUid': n_id,
  194. 'networkType': 'Wi-Fi',
  195. 'platform': 'iOS',
  196. 'requestId': 'fb972cbd4f390afcfd3da1869cd7d001',
  197. 'sessionId': '362290597725ce1fa870d7be4f46dcc2',
  198. 'subSessionId': '362290597725ce1fa870d7be4f46dcc2',
  199. 'title': new_title,
  200. 'token': '524a8bc871dbb0f4d4717895083172ab37c02d2f',
  201. 'uid': n_id,
  202. 'versionCode': '486',
  203. 'versionName': '3.4.12',
  204. 'videoFromScene': '1',
  205. 'videoPath': new_video_path,
  206. 'viewStatus': '1'
  207. }
  208. encoded_payload = urlencode(payload)
  209. response = requests.request("POST", url, headers=headers, data=encoded_payload)
  210. data = response.json()
  211. code = data["code"]
  212. if code == 0:
  213. new_video_id = data["data"]["id"]
  214. return new_video_id
  215. else:
  216. return ''
  217. """
  218. 票圈站内视频下载
  219. """
  220. @classmethod
  221. def download_video(cls, video_url, video_path_url, video_id):
  222. for i in range(3):
  223. payload = {}
  224. headers = {}
  225. response = requests.request("GET", video_url, headers=headers, data=payload)
  226. if response.status_code == 200:
  227. # 以二进制写入模式打开文件
  228. video = video_path_url + str(video_id) + '.mp4'
  229. with open(f"{video}", "wb") as file:
  230. # 将响应内容写入文件
  231. file.write(response.content)
  232. time.sleep(5)
  233. return video
  234. return ''