Complete code
#!/usr/bin/env python3
import os
import rospy
import cv2
import rosbag
from sensor_msgs.msg import Image
from cv_bridge import CvBridge
bag_name = '../2023-04-14-11-57-21.bag'
bag = rosbag.Bag(bag_name, "r")
bridge = CvBridge()
count = 0
image_topic = '/zed2/zed_node/left/image_rect_color'#'/zed2/zed_node/left/image_rect_color'
output_dir = '../Images/'
every = 2
for topic, msg, t in bag.read_messages(topics=image_topic):
if count%every == 0:
cv_img = bridge.imgmsg_to_cv2(msg, desired_encoding="passthrough")
name = output_dir+str(count)+'2.png'
cv2.imwrite( name, cv_img)
print ("Wrote image %i" % count)
count += 1
bag.close()
Breakdown
#!/usr/bin/env python3
rospy connects python to ROS. rosbag for reading from bagfilesimport os
import rospy
import cv2
import rosbag
bag_namebag_name = '../2023-04-14-11-57-21.bag'
bag = rosbag.Bag(bag_name, "r")CvBrdige for converting ros message Image to OpenCV image type for handling bridge = CvBridge()count = 0image_topic = '/zed2/zed_node/left/image_rect_color'output_dir = '../Images/'every = 2for topic, msg, t in bag.read_messages(topics=image_topic):n^th frame: if count%every == 0:
cv_img = bridge.imgmsg_to_cv2(msg, desired_encoding="passthrough")name = output_dir+str(count)+'2.png'cv2.imwrite( name, cv_img)count+=1bag.close