前言
用opencv多张尺寸相同图片生成一个视频。
一、使用os扩展库操作文件、分割字符串
- 读取指定文件夹下所有文件,存取这些文件的绝对路径。
fns = [os.path.join(root, fn) for root, dirs, files in os.walk(read_path + model_name + video_name) for fn in files]
- 读取第一个文件中以两个反斜杠分割的倒数第一个字符串。
fns[0].split('\\')[-1]
二、使用opencv扩展库
- 创建视频文件,第一个参数是合成之后的视频的名称,第二个参数是可以使用的编码器,第三个参数是帧率即每秒钟展示多少张图片,第四个参数是图片大小信息
videowrite = cv2.VideoWriter(read_path + model_name + video_name[0:3] + '-' + video_name[-1] + '.mp4', -1, 24, size)
- 读取所有要用的图片文件
for filename in [read_path + model_name + video_name + '/' + fns[i].split('\\')[-1] for i in range(len(fns))]:
img = cv2.imread(filename)
if img is None:
print(filename + " is error!") # 这句代码可以判断是否读取到图片文件
continue
img_array.append(img)
- 把读取的图片文件写进去
for i in range(len(fns)):
videowrite.write(img_array[i])
- 在不需要cv2.VideoWriter类对象时,需要将其释放。
videowrite.release()
总结
例如:以上就是今天要讲的内容,本文仅仅简单介绍了如何操作文件及创建一个视频。