python: bag包解析pcd和图像

bag包解析pcd和图像:


import glob, os
import rosbag
import cv2
from cv_bridge import CvBridge, CvBridgeError
import sensor_msgs.point_cloud2 as pc2
import numpy as np  

print(cv2.__version__)
bridge = CvBridge()
image_topic = "/usb_cam/image_raw/compressed"
point_topic = "/topic"
bagpath = "path"
for f in glob.glob(bagpath + "/*.bag"):
    print("bagfile:",f)
    img_path = os.path.dirname(f) + "/" + os.path.split(f)[-1][:-4] + "/jpg"
    pcd_path = os.path.dirname(f) + "/" + os.path.split(f)[-1][:-4] + "/pcd"

    if not os.path.exists(img_path):
        os.makedirs(img_path, mode=0o755)

    if not os.path.exists(pcd_path):
        os.makedirs(pcd_path, mode=0o755)

    cmd = "rosrun pcl_ros bag_to_pcd %s %s %s" % (f, point_topic, pcd_path)
    # print("cmd:", cmd)
    os.system(cmd)
    
    with rosbag.Bag(f, 'r') as bag:
        for topic, msg, t in bag.read_messages():
            print(topic, t)
            if topic == image_topic:
                try:
                    cv_image = bridge.compressed_imgmsg_to_cv2(msg, "bgr8")  #sensor_msgs::Image message to an OpenCV: bridege.imgmsg_to_cv2
                    cv2.imshow("window", cv_image)           
                    image_name = "%f" % msg.header.stamp.to_sec() + ".jpg"
                    file_path = os.path.join(img_path, image_name)
                    cv2.imwrite(file_path,cv_image)
                except CvBridgeError as e:
                    print(e)
                print("img saved done", )
            # if topic == point_topic:
            #     data = pc2.read_points(msg)
            #     points = np.array(list(data), dtype=np.float32)
            #     # print(points, len(points))
            #     filename = "%.6f" % msg.header.stamp.to_sec() + '.bin'
            #     file_path = os.path.join(pcd_path, filename)
            #     points.tofile(file_path)
            #     print(file_path)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ywfwyht

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值