2camera-pjibot_delivery.py 4.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. # -*- coding: utf-8 -*-
  2. # ------- 全局配置 -------
  3. import os
  4. import time
  5. import oss2
  6. import logging
  7. from resource import parse_robot_image
  8. from utils import json_utils
  9. path1 = '/mnt/disk001/dcl_data_process/src/python2/pjibot_delivery/'
  10. logging.basicConfig(filename=path1 + 'log/2camera-pjibot_delivery.log', level=logging.INFO,format='%(asctime)s - %(levelname)s - %(message)s')
  11. key1 = 'pjibot_delivery/'
  12. sleep_time = 10 # 每多少秒扫描一次
  13. error_bag_json = "/mnt/disk001/dcl_data_process/src/python2/pjibot_delivery/2camera-errorBag.json"
  14. # 1 创建阿里云对象
  15. auth = oss2.Auth('n8glvFGS25MrLY7j', 'xZ2Fozoarpfw0z28FUhtg8cu0yDc5d')
  16. endpoint = 'oss-cn-beijing-gqzl-d01-a.ops.gqzl-cloud.com'
  17. bucket = oss2.Bucket(auth, endpoint, 'open-bucket')
  18. # ------- 全局配置 -------
  19. def parse_to_mp4(merged_bag_file_path, parse_prefix1, local_parse_dir2, local_delete_list3):
  20. mp4_file_name = 'camera'
  21. local_mp4_file_path1 = local_mp4_dir + '/' + mp4_file_name + '.mp4'
  22. oss_csv_object_key1 = parse_prefix1 + mp4_file_name + '.mp4'
  23. try:
  24. flag, local_mp4_dir = parse_robot_image.parse(merged_bag_file_path, local_parse_dir2 + '/camera/')
  25. if flag:
  26. bucket.put_object_from_file(oss_csv_object_key1, local_mp4_file_path1)
  27. logging.info("上传 camera.mp4 成功: %s", str(oss_csv_object_key1))
  28. else:
  29. # 如果没有图像话题,也添加到错误列表,防止后面重复扫描生成
  30. json_utils.add_error(parse_prefix1,error_bag_json)
  31. logging.info("没有图像话题: %s", merged_bag_file_path)
  32. except Exception as e2:
  33. json_utils.add_error(parse_prefix1,error_bag_json)
  34. logging.exception("生成摄像头视频报错: %s", e2)
  35. finally:
  36. local_delete_list3.append(local_mp4_file_path1)
  37. local_delete_list.append(local_merged_bag_path)
  38. def judge(parse_prefix_full):
  39. camera_done = False
  40. for obj2 in oss2.ObjectIterator(bucket, prefix=parse_prefix_full):
  41. if '/camera.mp4' in str(obj2.key):
  42. camera_done = True
  43. if camera_done:
  44. return True
  45. def end_delete(local_delete_list):
  46. if len(local_delete_list) > 0:
  47. for local_delete in local_delete_list:
  48. try:
  49. os.remove(local_delete)
  50. except Exception as e:
  51. pass
  52. # ------- 获取合并之后的bag包,解析出csv -------
  53. if __name__ == '__main__':
  54. try:
  55. while True:
  56. logging.info("开始新一轮扫描")
  57. local_delete_list = []
  58. oss_delete_list = []
  59. prefix_list = []
  60. for obj1 in oss2.ObjectIterator(bucket, prefix=key1):
  61. try:
  62. merged_bag_object_key = str(obj1.key)
  63. if 'data_merge' in str(obj1.key) and str(obj1.key).endswith('.bag'):
  64. merged_bag_object_key_split = merged_bag_object_key.split('/')
  65. merged_prefix = '/'.join(merged_bag_object_key_split[:-1])
  66. parse_prefix = merged_prefix.replace('data_merge', 'data_parse')
  67. parse_prefix_full = merged_bag_object_key.replace('data_merge', 'data_parse')[:-4] + '/'
  68. if judge():
  69. continue
  70. local_merged_bag_path = path1 + 'camera/' + merged_bag_object_key
  71. local_merged_dir = '/'.join(local_merged_bag_path.split('/')[:-1])
  72. local_parse_dir = local_merged_dir.replace('data_merge', 'data_parse')
  73. if not os.path.exists(local_merged_dir):
  74. os.makedirs(local_merged_dir)
  75. if not os.path.exists(local_parse_dir):
  76. os.makedirs(local_parse_dir)
  77. merged_bag_full_name = merged_bag_object_key_split[-1]
  78. merged_bag_name = merged_bag_full_name.split('.')[0]
  79. bucket.get_object_to_file(merged_bag_object_key, local_merged_bag_path)
  80. logging.info("生成视频: %s" % str(obj1.key))
  81. parse_to_mp4(local_merged_bag_path, parse_prefix_full, local_parse_dir, local_delete_list)
  82. except Exception as e:
  83. logging.exception("局部异常处理: %s" % str(e))
  84. continue
  85. end_delete()
  86. time.sleep(sleep_time)
  87. except Exception as e:
  88. logging.exception("全局错误处理: %s" % str(e))