使用 openCV 从 numpy 数组生成视频

daV*_*nci 13 python video opencv ffmpeg codec

我正在尝试使用 openCV VideoWriter 类从 numpy 数组生成视频。我正在使用以下代码:

import numpy as np
import cv2
size = 720*16//9, 720
duration = 2
fps = 25
out = cv2.VideoWriter('output.avi', cv2.VideoWriter_fourcc(*'X264'), fps, size)
for _ in range(fps * duration):
    data = np.random.randint(0, 256, size, dtype='uint8')
    out.write(data)
out.release()
Run Code Online (Sandbox Code Playgroud)

编解码器似乎已安装,因为 ffmpeg 可以转换为 x264 编解码器,并且安装了 libx264。代码运行时没有警告,但是生成的视频似乎不包含数据,因为在尝试使用 mpv 读取它们时我总是收到以下消息:

[ffmpeg/demuxer] avi:找不到流 0 的编解码器参数(视频:h264 (X264 / 0x34363258),无,1280x720):未指定的像素格式

导致此问题的原因可能是什么?

Tys*_*son 19

第一个问题是您尝试使用黑白帧创建视频,而 VideoWriter 默认采用彩色。VideoWriter 有第 5 个布尔参数,您可以在其中传递 False 来指定视频为黑白。

第二个问题是 cv2 期望的维度与 numpy 相反。因此,大小应该是 (size[1], size[0])。

另一个可能的问题是所使用的编解码器。我一直无法让“X264”在我的机器上工作,而是一直使用“mp4v”作为编解码器,使用“.mp4”作为容器类型,以获得 H.264 编码输出。

当所有这些问题都解决之后,这就是结果。请尝试一下这个方法,看看它是否适合您:

import numpy as np
import cv2
size = 720*16//9, 720
duration = 2
fps = 25
out = cv2.VideoWriter('output.mp4', cv2.VideoWriter_fourcc(*'mp4v'), fps, (size[1], size[0]), False)
for _ in range(fps * duration):
    data = np.random.randint(0, 256, size, dtype='uint8')
    out.write(data)
out.release()
Run Code Online (Sandbox Code Playgroud)