video_processing.py 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import requests
  2. import json
  3. from common.aliyun_log import AliyunLogger
  4. from common.redis import get_video_data, install_video_data
  5. class VideoProcessing:
  6. def get_ai_data(self, video_path):
  7. url = "http://8.219.186.16:8080/process_video/"
  8. payload = json.dumps( {
  9. "video_path": video_path
  10. } )
  11. headers = {
  12. 'Content-Type': 'application/json'
  13. }
  14. response = requests.request( "POST", url, headers=headers, data=payload )
  15. try:
  16. response = response.json()
  17. print(response)
  18. result = response['result']
  19. print(result)
  20. cleaned_string = result.replace( "```json", "" ).replace( "```", "" ).strip()
  21. json_data = json.loads( cleaned_string )
  22. print(json_data)
  23. return json_data
  24. except Exception as e:
  25. print(f"视频请求异常:{e}")
  26. return None
  27. def get_video(self):
  28. video_data = get_video_data()
  29. if not video_data:
  30. print("没有获取到视频内容")
  31. return
  32. # 解码为字符串
  33. data_str = video_data.decode( 'utf-8' )
  34. # 解析为 JSON 对象
  35. data_json = json.loads( data_str )
  36. video_id = data_json['video_id']
  37. title = data_json['title']
  38. video_path = data_json['video_path']
  39. data = self.get_ai_data(video_path)
  40. AliyunLogger.logging(str(video_id), title, video_path, data)
  41. print("写入日志成功")
  42. if __name__ == '__main__':
  43. video_processor = VideoProcessing()
  44. video_processor.get_video()