Preface
最近在做 video caption 相关,要处理大量视频。
Method 1
方法 1 是最简单的,用 FFmpeg工具来完成。
具体的网上有很多这方面的资料,本人只是简单了解了一下如何使用。如下图,有一个名为 ffmpeg_test.avi 的视频:
在当前目录打开终端,输入如下命令:
$ffmpeg -i ffmpeg_test.avi frames_%03d.jpg -hide_banner
以上我没有指定太多的参数,实际上有很多参数可以指定,如起止的时间,几秒钟取一帧等等。
输入即可获得每一帧。
Method 2
下面就是可以用 cv2 模块中的 VideoCapture、VideoWriter 来提取了,具体代码如下:
#! encoding: UTF-8
import os
import cv2
import cv
videos_src_path = "/home/ou-lc/chenxp/Downloads/Youtube/youtube_select"
videos_save_path = "/home/ou-lc/chenxp/Downloads/Youtube/youtube_frames"
videos = os.listdir(videos_src_path)
videos = filter(lambda x: x.endswith("avi"), videos)
for each_video in videos:
print each_video
# get the name of each video, and make the direct