【python 自定义保存ros下bag包的某话题图像jpg】

功能

列出当前文件夹内的所有.bag文件 bag包的数据类型sensor_msgs/CompressedImage
让用户选择一个bag进行进一步操作
列出所选.bag文件中的所有话题,让用户选择一个话题
创建以话题名命名的文件夹的
解析该话题下的图像数据,将图像以时间戳命名保存到文件夹内

# -*- coding: utf-8 -*-
import os
import rosbag
from cv_bridge import CvBridge
import cv2
from sensor_msgs.msg import CompressedImage

def list_bag_files():
    """列出当前目录下的所有.bag文件"""
    return [file for file in os.listdir('.') if file.endswith('.bag')]

def select_bag_file(bag_files):
    """让用户从列表中选择一个.bag文件"""
    for i, file in enumerate(bag_files):
        print("{}{}. {}".format(i+1, ".", file))
    selection = int(input("请选择要解析的bag包的编号: ")) - 1
    return bag_files[selection]

def list_topics_in_bag(bag_file):
    """列出指定bag文件中的所有话题"""
    bag = rosbag.Bag(bag_file, 'r')
    topics = bag.get_type_and_topic_info()[1].keys()
    bag.close()
    return topics

def select_topic(topics):
    """让用户从列表中选择一个话题"""
    for i, topic in enumerate(topics):
        print("{}{}. {}".format(i+1, ".", topic))
    selection = int(input("请选择要解析的话题的编号: ")) - 1
    return list(topics)[selection]

def create_topic_folder(topic_name):
    """创建以话题名称为名的文件夹,如果文件夹不存在"""
    folder_name = topic_name.replace('/', '_')[1:]  # 移除话题名称前的斜杠并替换剩余的斜杠为下划线
    if not os.path.exists(folder_name):
        os.makedirs(folder_name)
    return folder_name

def extract_images_from_bag(bag_file, topic):
    """从选定的bag包和话题中提取图像数据"""
    bag = rosbag.Bag(bag_file, 'r')
    bridge = CvBridge()
    topic_folder = create_topic_folder(topic)  # 创建存储图像的文件夹

    for _, msg, t in bag.read_messages(topics=[topic]):
        if hasattr(msg, 'header'):
            timestamp_secs = msg.header.stamp.secs
            timestamp_nsecs = msg.header.stamp.nsecs
            timestamp_msecs = int(timestamp_nsecs / 1000000)
            datetime_format = "{}.{:03}".format(timestamp_secs, timestamp_msecs)
            image_name = 'img_{}.jpg'.format(datetime_format)
            image_path = os.path.join(topic_folder, image_name)  # 构建图像文件的完整路径

            cv_image = bridge.compressed_imgmsg_to_cv2(msg, desired_encoding="passthrough")
            cv2.imwrite(image_path, cv_image)
            print("图像已保存至:{}".format(image_path))

    bag.close()
    print("完成。图像已提取至'{}'文件夹。".format(topic_folder))

if __name__ == '__main__':
    bag_files = list_bag_files()
    if not bag_files:
        print("当前目录下没有找到.bag文件。")
    else:
        selected_bag_file = select_bag_file(bag_files)
        topics = list_topics_in_bag(selected_bag_file)
        if not topics:
            print("选定的bag包中没有找到话题。")
        else:
            selected_topic = select_topic(topics)
            extract_images_from_bag(selected_bag_file, selected_topic)

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值