python3 opencv截取视频_录制的视频,使用python opencv去截取帧数(只取某一帧)同时可裁剪图像尺寸...

coding: utf-8

指定某一帧截取图像(不包括裁剪)

import cv2 as cv

import os

1.读取视频文件夹

filepath = './Input_video' # 需要读取的视频的路径

pathDir = os.listdir(filepath) # 获取文件夹中文件名称

2.截视频帧数

for allDir in pathDir: # 逐个读取视频文件

a = 80# 截取指定帧数

videopath = r'./Input_video/'+allDir # 视频文件路径

vc = cv.VideoCapture(videopath) # 读入视频文件

# 存储视频的子目录

path = './Video_Result(Only-1)Frame/'#+allDir.split('.')[0] # 文件夹名称 + 以什么符号分割,此处选择直接放进一个文件夹中

if not os.path.exists(path): # 如果不存在就创建文件夹

os.mkdir(path)

if vc.isOpened(): # 判断载入的视频是否能够打开

rval , frame = vc.read()

else:

rval = False

while rval:

vc.set(cv.CAP_PROP_POS_FRAMES, a) # 截取指定帧数

rval,frame = vc.read() # 分帧读取视频

#frame = frame[130:920,380:1420]

cv.imencode('.jpg',frame)[1].tofile(path +'/' + str(a) +'-'+ allDir[:-4] + '.jpg')

print(str(a) +'-'+ allDir[:-4] + '---视频截取完成')

break

print('\n','处理完成,请移步------→ :Video_Result(Only-1)Frame查看结果')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、问题的提出 做运动分析检测,需要有一定的素材视频,但是素材视频的编码OpenCV不能识别,无法对指定的视频做实验,怎么素材视频通用化使得OpenCV能正常识别? 二、解决的方法 (1)素材视频总是有配套的播放器来播放,那么使用这个播放器查看总,和总播放时长,计算出帧率为25,表示一秒钟播放25图像。 (2)用这个配套的播放器对素材视频进行逐步进抓图,这个操作很辛苦,一秒钟25,那么抓25是一秒,素材视频30秒就要抓750,很辛苦。 (3)抓完后,发现一帧图1.4M,以位图格式保存,那么30秒就要达到1G的存储空间,怎么办?没办法,不知道怎么去获取解码器和安装解码器,就只能这么忍受。察看到逐步进抓图的存储是按序列编排文件名,那么要修改好使得每个文件名都是以规则“文件名”+“序列”的形式存在。 (4)编写根据序列图生成帧率25的视频的代码 三、问题的解决: (1)解决一个字符串合并的问题: 由于字符串参有个赋值格式化设置函叫做Format,要实现多类型参的字符串化,可以参照如下示例: float f = 0.0; char sz[128]; int n = 1; CString str; str.Format("%f%s%d",f,sz,n); (2)采用MJPG的编码格式依次将这些图像序列写入到视频中保存起来,采用MJPG的编码格式是因为操作系统自带了Media player播放器,这种编码格式属于无压缩的,Media player可以识别播放。 (3)实现方式是使用MFC对话框窗体的按钮事件来进行视频的逐写图,由于多,那么在写入器循环做写这个动作的时候,整个程序是假死在那里直到写入器的写入操作终结。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值