piaoquan_utils.py 9.6 KB

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