Opencv-python——视频帧的读取和重新保存

大家在做传统的图像处理和深度学习时经常用到对 视频的处理,这里放上python的opencv库实现的源码,功能是

读取视频的每一帧,将每一帧进行操作后重新整合成一个新的视频

,供大家参考使用:

import cv2

cap = cv2.VideoCapture('视频路径')

fourcc = cv2.VideoWriter_fourcc(*'XVID')

frame_width = int(cap.get(3))
frame_height = int(cap.get(4))
fps = cap.get(5)

out = cv2.VideoWriter('output.avi', fourcc, fps, (frame_width,frame_height))

if cap.isOpened():
    ret,frame = cap.read()
else:
    ret = False

while ret:
    ret,frame  = cap.read()
    if frame is not None:
        '''
        这里是一系列帧操作,假设处理完后的帧名叫img
        '''

        out.write(img)

cap.release()
out.release()

这一串源码,大家在 修改自己的视频路径填充自己需要的帧处理操作后可直接使用。

除了上述给出的注释外,写下一些使用时的 注意点

1.关于编码格式fourcc的选择,不限于这里的”XVID格式”:

cv2.VideoWriter_fourcc(‘I’, ‘4’, ‘2’, ‘0’),该参数是YUV编码类型,文件名后缀为.avi
cv2.VideoWriter_fourcc(‘P’, ‘I’, ‘M’, ‘I’),该参数是MPEG-1编码类型,文件名后缀为.avi
cv2.VideoWriter_fourcc(‘X’, ‘V’, ‘I’, ‘D’),该参数是MPEG-4编码类型,文件名后缀为.avi
cv2.VideoWriter_fourcc(‘T’, ‘H’, ‘E’, ‘O’),该参数是Ogg Vorbis,文件名后缀为.ogv
cv2.VideoWriter_fourcc(‘F’, ‘L’, ‘V’, ‘1’),该参数是Flash视频,文件名后缀为.flv

2.cv2.VideoWriter()函数,第一个参数是输出视频名称,第二个参数就是视频编码格式,第三个参数是输出视频的帧率( 可以任意选择),输出帧的尺寸( 这个非常关键,要确保输出帧的尺寸和输入图像一致,否则输出的视频将出现错误,这里采用了cap.get方法解决)。

3.if frame is not None 不能省去,因为在视频读取完最后一帧后,ret的值将依旧为真,而frame值为空,如果不加这句将导致视频读取完后报错读不到frame: ‘NoneType’ object has no attribute ‘shape’

  1. 注释部分以窗口的形式呈现输出视频,大家可以自行调整窗口的尺寸和相关设置。

注意:

如果最后输出的视频 只有几KB大小,并且无法打开,很可能是cv2.VideoWriter出了问题,主要检查 fourcc帧宽帧高的设置。

Original: https://blog.csdn.net/weixin_52005740/article/details/125857039
Author: 晨风默语
Title: Opencv-python——视频帧的读取和重新保存

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/633481/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球