Python:使用FFMPEG使用一系列图像创建视频

时间:2019-02-04 16:34:38

标签: python ffmpeg

我对Python相当陌生,这是我第一次使用ffmpeg(此代码基于同事)。

我有一些代码,每隔X秒拍摄一次屏幕快照,然后从这些文件中创建视频,但是在创建视频时遇到了问题。这是我生成视频的代码:

def create_video(screen_resolution, image_location, subfolder, count, preset, qaulity, duplicated_frame, video_path, video_filename):
video_path = path + video_path
    {1}\\%d.jpg -vcodec libx264 -preset {2} -crf {3} -r {4} -pix_fmt yuv420p {5}\\{6}.mp4"
proc = subprocess.Popen("C:\\ffmpeg\\ffmpeg.exe -r 1 -f image2 -s %s \
                            -pattern_type sequence \
                            -start_number 1 \
                            -i %s%s\\%s%d.png \
                            -vcodec libx264 \
                            -preset %s \
                            -crf %s \
                            -r %s \
                            -pix_fmt yuv420p \
                            %s\\%s.mp4" %
                            (screen_resolution, image_location, subfolder, count, preset[2], qaulity, duplicated_frame, video_path, video_filename), shell = True)

我得到的错误是:

TypeError:%d格式:需要数字,而不是str

我曾尝试寻找解决方案,但并没有很快得到解决。我知道%d在末尾从列表中寻找输入,但是从我所看到的来看,这也是告诉FFMPEG使用图像位置中的所有文件的方式。

希望有人可以提供帮助,如果这是一个重复的问题,我深表歉意,但是如上所述,我已经尝试了很多搜索。

1 个答案:

答案 0 :(得分:1)

不要尝试手动构造外壳程序字符串。让subprocess为您做到这一点。

您可以传递一组命令行参数,Popen将负责正确转义所有内容:

proc = subprocess.Popen(
    [
        "C:/ffmpeg/ffmpeg.exe",
        "-r", "1",
        "-f", "image2",
        "-s", screen_resolution,
        "-i", os.path.join(path, image_location, subfolder, "%d" + extension),
        "-preset", preset[1],
        "-crf", str(qaulity),
        "-r", str(duplicated_frame),
        "-pix_fmt", "yuv420p",
        os.path.join(video_path, video_filename)
    ]
)