1

我的任务涉及使用 ffmpeg 从图像序列创建视频。下面的代码解决了这个问题。

import ffmpeg

video = ffmpeg.input('/path/to/images/*.jpg', pattern_type='glob',framerate=20).output(video.mp4).run()

然而,由于我们得到的图像数据遵循模式

1.jpg,
2.jpg,
3.jpg
.
.
20.jpg
.
.
100.jpg

视频是用 glob 模式创建的1.jpg, 100.jpg, 11.jpg, 12.jpg, ... 2.jpg, 20.jpg, 21.jpg ... ,观看起来非常不愉快。

无论如何,我可以传递一个列表或其他任何东西,除了一个路径/全局模式,图像按顺序排序。另外,如果我可以选择要添加哪些文件作为输入法,我会很高兴input()

4

1 回答 1

1

您可以使用Concat demuxer

  • mylist.txt使用以下格式的所有图像文件创建一个文件:

     file '/path/to/images/1.jpg'
     file '/path/to/images/2.jpg'
     file '/path/to/images/3.jpg'
     file '/path/to/images/20.jpg'
     file '/path/to/images/100.jpg'
    

    您可以mylist.txt手动创建,也可以使用 Python 代码创建文本文件。

  • 使用以下命令(您可以选择不同的编解码器):

     ffmpeg.input('mylist.txt', r='20', f='concat', safe='0').output('video.mp4', vcodec='libx264').run()
    

第二种选择:
将JPEG数据写入FFmpeg子进程的stdin PIPE。

  • 创建 JPEG 文件名列表(Python 列表)。
  • 执行FFmpeg子流程,输入为stdin PIPE,jpeg_pipe输入格式。
  • 迭代列表,读取每个文件的内容并将其写入 stdin PIPE。
  • 关闭标准输入管道。

这是一个代码示例:

import ffmpeg

# List of JPEG files
jpeg_files = ['/tmp/0001.jpg', '/tmp/0002.jpg', '/tmp/0003.jpg', '/tmp/0004.jpg', '/tmp/0005.jpg']

# Execute FFmpeg sub-process, with stdin pipe as input, and jpeg_pipe input format
process = ffmpeg.input('pipe:', r='20', f='jpeg_pipe').output('/tmp/video.mp4', vcodec='libx264').overwrite_output().run_async(pipe_stdin=True)

# Iterate jpeg_files, read the content of each file and write it to stdin
for in_file in jpeg_files:
    with open(in_file, 'rb') as f:
        # Read the JPEG file content to jpeg_data (bytes array)
        jpeg_data = f.read()

        # Write JPEG data to stdin pipe of FFmpeg process
        process.stdin.write(jpeg_data)

# Close stdin pipe - FFmpeg fininsh encoding the output file.
process.stdin.close()
process.wait()
于 2021-04-18T19:51:50.260 回答