# -*- coding: utf-8 -*- import os import time import oss2 import xml.etree.ElementTree as ET from rosbag import Bag, Compression import shutil import docker import bagtocsv_orig import bagtocsv_hmi import get_drive import parse_jinlong_image import pcdtovideo_jilong_overlook import pcdtovideo_jilong_forwardlook key1 = 'kinglong/' path1 = '/scenarios/' sleep_time = 5 # 每多少秒扫描一次 def move_xosc_before_simulation(root_path1, root_path2): try: xodr1 = 'thq.xodr' xodr2 = 'OpenDRIVE.xodr' xodr3 = 'gelan.xodr' osgb1 = 'thq.opt.osgb' osgb2 = 'GJBM_20km_0822.opt.osgb' osgb3 = 'gelan.opt.osgb' tree1 = ET.parse(root_path1 + 'scenario_orig.xosc') root1 = tree1.getroot() for node0 in root1: if node0.tag == 'RoadNetwork': for node1 in node0: # 打印根元素的标签名 src_file_prefix = '/root/rosmerge/resource/' if 'LogicFile' == node1.tag: if xodr1 in node1.get('filepath'): dst_file = root_path1 + xodr1 shutil.copy(src_file_prefix + xodr1, dst_file) node1.set('filepath', dst_file) if xodr2 in node1.get('filepath'): dst_file = root_path1 + xodr2 shutil.copy(src_file_prefix + xodr2, dst_file) node1.set('filepath', dst_file) if xodr3 in node1.get('filepath'): dst_file = root_path1 + xodr3 shutil.copy(src_file_prefix + xodr3, dst_file) node1.set('filepath', dst_file) if 'SceneGraphFile' == node1.tag: if osgb1 in node1.get('filepath'): dst_file = root_path1 + osgb1 shutil.copy(src_file_prefix + osgb1, dst_file) node1.set('filepath', dst_file) if osgb2 in node1.get('filepath'): dst_file = root_path1 + osgb2 shutil.copy(src_file_prefix + osgb2, dst_file) node1.set('filepath', dst_file) if osgb3 in node1.get('filepath'): dst_file = root_path1 + osgb3 shutil.copy(src_file_prefix + osgb3, dst_file) node1.set('filepath', dst_file) if node0.tag == 'Entities': for node1 in node0: if node1.get("name") == 'Ego': for node2 in node1: if node2.tag == 'Vehicle': node2.set('name', 'KingLong_snow white') tree1.write(root_path1 + 'openx0.xosc') tree2 = ET.parse(root_path2 + 'scenario_hmi.xosc') root2 = tree2.getroot() for node0 in root2: if node0.tag == 'RoadNetwork': for node1 in node0: # 打印根元素的标签名 src_file_prefix = '/root/rosmerge/resource/' if 'LogicFile' == node1.tag: if xodr1 in node1.get('filepath'): dst_file = root_path2 + xodr1 shutil.copy(src_file_prefix + xodr1, dst_file) node1.set('filepath', dst_file) if xodr2 in node1.get('filepath'): dst_file = root_path2 + xodr2 shutil.copy(src_file_prefix + xodr2, dst_file) node1.set('filepath', dst_file) if xodr3 in node1.get('filepath'): dst_file = root_path2 + xodr3 shutil.copy(src_file_prefix + xodr3, dst_file) node1.set('filepath', dst_file) if 'SceneGraphFile' == node1.tag: if osgb1 in node1.get('filepath'): dst_file = root_path2 + osgb1 shutil.copy(src_file_prefix + osgb1, dst_file) node1.set('filepath', dst_file) if osgb2 in node1.get('filepath'): dst_file = root_path2 + osgb2 shutil.copy(src_file_prefix + osgb2, dst_file) node1.set('filepath', dst_file) if osgb3 in node1.get('filepath'): dst_file = root_path2 + osgb3 shutil.copy(src_file_prefix + osgb3, dst_file) node1.set('filepath', dst_file) if node0.tag == 'Entities': for node1 in node0: if node1.get("name") == 'Ego': for node2 in node1: if node2.tag == 'Vehicle': node2.set('name', 'KingLong_snow white') tree2.write(root_path2 + 'openx0.xosc') except Exception as e: print "修改xosc报错: %s" % str(e) # print(f'修改xosc报错:{e}') def delete_files_in_dir(dir_path): # 遍历目录下的所有文件和子目录 for root, dirs, files in os.walk(dir_path): for file in files: file_path = os.path.join(root, file) try: os.remove(file_path) except OSError as e: print("删除文件时出错:", file_path, "-", e.strerror) # 扫描目录上传mp4 def upload_simulation(parse_prefix, mp41, mp42): try: bucket.put_object_from_file(parse_prefix + 'scenario_orig.mp4', mp41) print '上传仿真视频到 %s' % parse_prefix + 'scenario_orig.mp4' bucket.put_object_from_file(parse_prefix + 'scenario_hmi.mp4', mp42) print '上传仿真视频到 %s' % parse_prefix + 'scenario_hmi.mp4' shutil.rmtree(path1) except Exception as e: print "上传视频报错: %s" % str(e) # print(f'上传视频报错{e}') def simulation(parse_prefix, mp41, mp42): try: os.system("docker start vtd") # 实例化Docker客户端 client = docker.from_env() while True: time.sleep(5) # 获取容器列表 containers = client.containers.list() run = False # 打印容器列表 for container in containers: if 'vtd' == container.name: run = True break if not run: break time.sleep(5) upload_simulation(parse_prefix, mp41, mp42) except Exception as e: print "生成仿真视频报错: %s" % str(e) # print(f'生成仿真视频报错{e}') def is_upload_completed(bucket, prefix): target_number = str(prefix).split('_')[-1][:-1] count = 0 for obj in oss2.ObjectIterator(bucket, prefix=prefix): if obj.key != prefix: count += 1 return int(count) == int(target_number) ''' cname:http://open-bucket.oss.icvdc.com 内网endpoint: oss-cn-beijing-gqzl-d01-a.ops.gqzl-cloud.com oss桶名: open-bucket keyid:n8glvFGS25MrLY7j secret:xZ2Fozoarpfw0z28FUhtg8cu0yDc5d ''' # ------- 获取合并之后的bag包,解析出csv ------- if __name__ == '__main__': # 1 创建阿里云对象 auth = oss2.Auth('n8glvFGS25MrLY7j', 'xZ2Fozoarpfw0z28FUhtg8cu0yDc5d') # cname = 'http://open-bucket.oss.icvdc.com' # bucket = oss2.Bucket(auth, cname, 'open-bucket', is_cname=True) endpoint = 'oss-cn-beijing-gqzl-d01-a.ops.gqzl-cloud.com' bucket = oss2.Bucket(auth, endpoint, 'open-bucket') while True: local_delete_list = [] oss_delete_list = [] prefix_list = [] # 2 获取已经上传完成的所有目录并分组 all_prefix_set = set() for obj1 in oss2.ObjectIterator(bucket, prefix=key1): # 获取csv if 'data_parse' in str(obj1.key) and str(obj1.key).count('/') == 4: all_prefix_set.add('/'.join(str(obj1.key).split('/')[:-1]) + '/') for obj2_key in all_prefix_set: xosc1_done = False xosc2_done = False mp41_done = False mp42_done = False for obj3 in oss2.ObjectIterator(bucket, prefix=obj2_key): if '/scenario_orig.xosc' in str(obj3.key): xosc1_done = True if '/scenario_hmi.xosc' in str(obj3.key): xosc2_done = True if '/scenario_orig.mp4' in str(obj3.key): mp41_done = True if '/scenario_hmi.mp4' in str(obj3.key): mp42_done = True if not xosc1_done or not xosc2_done: continue if mp41_done and mp42_done: continue # print(f'需要生成xosc:{obj2_key}') print "需要生成仿真视频: %s" % obj2_key parse_prefix_full = obj2_key local_dir_full = path1 + parse_prefix_full if not os.path.exists(local_dir_full): os.makedirs(local_dir_full) # 下载两个csv root_path1 = local_dir_full + 'orig/' root_path2 = local_dir_full + 'hmi/' if not os.path.exists(root_path1): os.makedirs(root_path1) if not os.path.exists(root_path2): os.makedirs(root_path2) bucket.get_object_to_file(parse_prefix_full + 'scenario_orig.xosc', root_path1 + 'scenario_orig.xosc') bucket.get_object_to_file(parse_prefix_full + 'scenario_hmi.xosc', root_path2 + 'scenario_hmi.xosc') local_delete_list.append(root_path1 + 'scenario_orig.xosc') local_delete_list.append(root_path2 + 'scenario_hmi.xosc') move_xosc_before_simulation(root_path1, root_path2) simulation(parse_prefix_full, root_path1 + 'simulation.mp4', root_path2 + 'simulation.mp4') # 删除本地临时文件 if len(local_delete_list) > 0: for local_delete in local_delete_list: try: os.remove(local_delete) except Exception as e: print "删除本地临时文件报错: %s" % str(e) # print(f'删除本地临时文件报错{e}') time.sleep(sleep_time)