piaoquan_utils.py 11 KB

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