时间:2021-05-22
我是在做行人检测中需要将一段视频变为图片数据集,然后想将视频每秒钟的图片提取出来。
opencv中提供了读取视频每帧图片的函数,下面的代码可以将视频的每帧图片提取出来。注:我的视频名字叫 2.mp4 ,提取图片保存目录 需要自己建一个名字叫 output 的文件夹。
# 导入所需要的库import cv2import numpy as np # 定义保存图片函数# image:要保存的图片名字# addr;图片地址与相片名字的前部分# num: 相片,名字的后缀。int 类型def save_image(image,addr,num): address = addr + str(num)+ '.jpg' cv2.imwrite(address,image) # 读取视频文件videoCapture = cv2.VideoCapture("2.mp4")# 通过摄像头的方式# videoCapture=cv2.VideoCapture(1) #读帧success, frame = videoCapture.read()i = 0while success : i = i + 1 save_image(frame,'./output/image',m) if success: print('save image:',i) success, frame = videoCapture.read()现在我想按秒提取,只要我们能知道视频每秒有多少帧,然后在上面的代码基础上每隔那么多帧提取一次就行了,这就需要查看视频的帧率。一般情况下随便用一个播放器打开视频后右键查看其属性就可以看到帧率。现在我的视频帧率为12,每隔12帧提取一次就可以得到每秒的图片。代码如下:
# 导入所需要的库import cv2import numpy as np # 定义保存图片函数# image:要保存的图片名字# addr;图片地址与相片名字的前部分# num: 相片,名字的后缀。int 类型def save_image(image,addr,num): address = addr + str(num)+ '.jpg' cv2.imwrite(address,image) # 读取视频文件videoCapture = cv2.VideoCapture("2.mp4")# 通过摄像头的方式# videoCapture=cv2.VideoCapture(1) #读帧success, frame = videoCapture.read()i = 0timeF = 12j=0while success : i = i + 1 if (i % timeF == 0): j = j + 1 save_image(frame,'./output/image',j) print('save image:',i) success, frame = videoCapture.read()以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python实现从log日志中提取ip的方法。分享给大家供大家参考,具体如下:log日志内容如下(myjob.log):124.90.53.68-
假如文件夹有大量视频文件,需求目标是想从每个视频中提取一帧作为视频的一个封面图片,本文利用opencv-python模块实现需求。结合自己的工作,做一下简单的记
极强PDF转换器怎么从PDF文件中提取图片?想要从PDF文件中提取图片,方法其实相当简单,大家可以通过使用极强PDF转换器来获取想要的图片,具体应该如何操作呢?
本文实例讲述了Python实现从URL地址提取文件名的方法。分享给大家供大家参考。具体分析如下:如:地址为https://www.jb51.net/images
docx2txt的Github地址docx2txt是基于python的从docx文件中提取文本和图片的库。代码是从python-docx中获取的。它也可以从页眉