我想把一个100 GB的玫瑰花袋分成100个1 GB的袋子。我尝试使用rosbag过滤器,但它需要很长时间,因为我必须手动运行每个过滤器,每次,它都会扫描整个袋子。有没有更好的方法来执行这种拆分(通过命令行或Python脚本)?
发布于 2018-07-17 22:25:07
您可以简单地使用如下函数将您的包文件拆分成块:
import rosbag
def extract_chunks(file_in, chunks):
bagfile = rosbag.Bag(file_in)
messages = bagfile.get_message_count()
m_per_chunk = int(round(float(messages) / float(chunks)))
chunk = 0
m = 0
outbag = rosbag.Bag("chunk_%04d.bag" % chunk, 'w')
for topic, msg, t in bagfile.read_messages():
m += 1
if m % m_per_chunk == 0:
outbag.close()
chunk += 1
outbag = rosbag.Bag("chunk_%04d.bag" % chunk, 'w')
outbag.write(topic, msg, t)
outbag.close()请注意,此方法使用消息数量来执行拆分,因此生成的块包文件不一定具有相同的大小。
https://stackoverflow.com/questions/48545368
复制相似问题