如何将图片保存成视频(imageio、opencv和ffmpeg)

测试下来发现,imageio 速度比 cv2 的要慢,所以普通保存推荐 cv2,要gpu加速需要额外配置或者修改

imageio

底层也是调用的ffmpeg,以下是python代码

python 复制代码
import imageio
import os

# 读取要保存为视频的图片
images = []
for filename in os.listdir('path/to/images/folder'):
    images.append(imageio.imread('path/to/images/folder/' + filename))

# 指定保存视频的名称和帧率
video_name = 'output_video.mp4'
fps = 25

# 使用 imageio 保存视频
with imageio.get_writer(video_name, fps=fps) as video_writer:
    for image in images:
        video_writer.append_data(image)

在上面的代码中,我们首先使用 os.listdir() 函数获取要保存为视频的所有图片的文件名,然后使用 imageio.imread() 函数读取每个文件并将其添加到 images 列表中。接下来,我们指定要保存的视频的名称和帧率。最后,我们使用 imageio.get_writer() 函数创建一个视频写入器,然后使用 video_writer.append_data() 函数将每个图像添加到视频中。

这样,您就可以使用 imageio 库保存视频了。请确保您已经正确指定了要保存的图片路径和视频名称,并指定了正确的帧率。

cv2

python 复制代码
import cv2
import os

#图片路径
im_dir = '/home/x/out/xxx_imags'
#输出视频路径
video_dir = '/home/xxxx/out/xxxx.avi'
#帧率
fps = 30  
#图片数 
num = 426
#图片尺寸
img_size = (841,1023)

#fourcc = cv2.cv.CV_FOURCC('M','J','P','G')#opencv2.4
fourcc = cv2.VideoWriter_fourcc('M','J','P','G') #opencv3.0
videoWriter = cv2.VideoWriter(video_dir, fourcc, fps, img_size)

for i in range(1,num):
    im_name = os.path.join(im_dir, str(i).zfill(6)+'.jpg')
    frame = cv2.imread(im_name)
    videoWriter.write(frame)
    print im_name

videoWriter.release()
print 'finish'

ffmpeg

from : https://blog.csdn.net/xindoo/article/details/121451318

python 复制代码
ffmpeg -r 10 -f image2 -i %d.jpeg output1.mp4

GPU加速

可能能加速10倍以上,但是需要安装GPU版本
Ubuntu上安装ffmpeg-cuda加速
替换Python的imageio包中自带的ffmpeg以支持GPU编解码加速

https://www.jianshu.com/p/59da3d350488

相关推荐
中议视控30 分钟前
浅谈会议室展厅多功能厅指挥中心音视频产品的各种内嵌软件:无线话筒,数字会议系统,网络中控主机,高清无缝混合矩阵,视频会议终端,摄像头,分布式终端
物联网·音视频·软件需求
智驱力人工智能37 分钟前
实线变道检测 高架道路安全治理的工程化实践 隧道压实线监测方案 城市快速路压实线实时预警 压实线与车牌识别联动方案
人工智能·opencv·算法·安全·yolo·边缘计算
光羽隹衡1 小时前
计算机视觉--Opencv(模板匹配)
人工智能·opencv·计算机视觉
想你依然心痛1 小时前
AI 视频生成新时代:Wan2.2-T2V-A5B 文本转视频实战
人工智能·音视频·ai视频
weixin_690654741 小时前
#龙迅LT6911D 高性价比IC ,功能适用于HDMI转两 PORT MIPIDSI/CSI,分辨率高达4K。
音视频·信号处理
ViiTor_AI1 小时前
AI 语音克隆入门指南:如何用 3 秒音频生成真实人声?
人工智能·音视频·语音识别
无垠的广袤2 小时前
【VisionFive 2 Lite 单板计算机】边缘AI视觉应用部署:人脸检测
linux·人工智能·python·opencv·开发板
步达硬件2 小时前
【Matlab】把视频里每一帧存为单独的图片
开发语言·matlab·音视频
JERRY. LIU2 小时前
realsense识别目标距离的传感器及其工作原理
python·opencv·目标检测
ViiTor_AI2 小时前
2026 年 AI 配音工具深度对比:视频旁白与有声书为什么越来越依赖语音克隆?
人工智能·音视频·语音识别