首先导入库:
# _*_ coding:utf-8 _*_
import time
import cv2
import os
然后,下面几行代码就可以提取视频中的图片:
import cv2
import os
def getFrame(videoPath, svPath):
#读取视频
cap = cv2.VideoCapture(videoPath)
numFrame = 0
fps = cap.get(cv2.CAP_PROP_FPS) #获取视频的帧率
print(fps)
while True:
if cap.grab():
'''
flag:按帧读取视频,返回值ret是布尔型,正确读取则返回True
frame:为每一帧的图像
'''
flag, frame = cap.retrieve() #解码,并返回捕获的视频帧
if not flag:
continue
else:
cv2.imshow('video', frame)
numFrame += 1
#拼接图片保存路径
newPath = svPath + "\\图片" + str(numFrame) + ".jpg"
#将图片按照设置格式,保存到文件
cv2.imencode('.jpg', frame)[1].tofile(newPath)
if numFrame == 10:
#只保存10张图片,程序结束
cap.release() #释放读取画面状态
break
else:
pass
if cv2.waitKey(10) == 27:
break
if __name__ == '__main__':
videopath = r'D:\Python_studyltem\视频转化为图片\自动化测试平台培训视频.mp4' #自行更改路径
svpath = r'D:\Python_studyltem\视频转化为图片\imgs' #图片保存路径
if os.path.exists(svpath):
pass
else:
os.mkdir(svpath)
getFrame(videopath,svpath)