新闻动态

python+opencv实现视频抽帧示例代码

发布日期:2022-03-12 18:43 | 文章来源:CSDN

1、数据集简述:

虽然有主流庞大的COCO、VOC数据集,但是科研人员仍需要特殊领域要求的数据集,所以采用人工实地采集的方式进行收集数据集图像;通过拍照收集图像过于繁琐,所以通常是将摄像头无规则的移动旋转以及远近拉缩,进而录制视频;再通过视频抽帧的方式得到大量的图像,再将这些图像进行人工标注处理。

博主通过一个水下录制视频为例子,当这类图像在网上鲜有存在时,要求有关技术人员进行实拍采集,下图即为采集得到的视频。

为了避免不符合项目要求的数据增强,博主要求技术人员在录制视频时最大程度地让摄像头进行移动、旋转以及远近调节等;这样抽帧后的图像更具有泛化性

2、代码介绍:

下面是采用以帧数为间隔的方法进行视频抽帧,博主个人认为这样子的方式调节间隔更加方便,更符合个人习惯。

import cv2
from PIL import Image
import numpy as np

cap = cv2.VideoCapture("D:/Download/ANMR0005.mp4")  # 获取视频对象
isOpened = cap.isOpened  # 判断是否打开
# 视频信息获取
fps = cap.get(cv2.CAP_PROP_FPS)
imageNum = 0
sum=0
timef=15  #隔15帧保存一张图片
while (isOpened):
 sum+=1
 (frameState, frame) = cap.read()  # 记录每帧及获取状态
 if frameState == True and (sum % timef==0):
  # 格式转变,BGRtoRGB
  frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
  # 转变成Image
  frame = Image.fromarray(np.uint8(frame))
  frame = np.array(frame)
  # RGBtoBGR满足opencv显示格式
  frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR)
  imageNum = imageNum + 1
  fileName = 'D:/Download/video_image/image' + str(imageNum) + '.jpg'  # 存储路径
  cv2.imwrite(fileName, frame, [cv2.IMWRITE_JPEG_QUALITY, 100])
  print(fileName + " successfully write in")  # 输出存储状态
 elif frameState == False:
  break
print('finish!')
cap.release()

3、代码效果:

pycharm运行py文件后结果框显示的内容:

视频抽帧得到的图像保存至指定的文件夹:

抽帧得到的图片示例:

4、相关说明: ①本代码依据录制视频、对opencv的理解以及大佬的项目代码灵感进行编写;

大佬的项目代码地址

②本数据集属于私人闭源,不公开。

到此这篇关于python+opencv实现视频抽帧的文章就介绍到这了,更多相关python opencv视频抽帧内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!

香港服务器租用

版权声明:本站文章来源标注为YINGSOO的内容版权均为本站所有,欢迎引用、转载,请保持原文完整并注明来源及原文链接。禁止复制或仿造本网站,禁止在非www.yingsoo.com所属的服务器上建立镜像,否则将依法追究法律责任。本站部分内容来源于网友推荐、互联网收集整理而来,仅供学习参考,不代表本站立场,如有内容涉嫌侵权,请联系alex-e#qq.com处理。

相关文章

实时开通

自选配置、实时开通

免备案

全球线路精选!

全天候客户服务

7x24全年不间断在线

专属顾问服务

1对1客户咨询顾问

在线
客服

在线客服:7*24小时在线

客服
热线

400-630-3752
7*24小时客服服务热线

关注
微信

关注官方微信
顶部