时间:2021-05-22
这篇文章主要介绍了Python OpenCV视频截取并保存实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
在图像处理之前,我们需要对拿到手的数据进行筛选,对于视频,我们需要从中截取我们需要的一段或几段
整体思路比较简单,通过设定截取视频的起止时间(帧数),可以将该时间段内的图像保存为新的视频
直接上代码
"""【函数名称】 截取视频 【参数】 输入参数 视频文件名称【详细介绍】 输入不同时间段 进行截取拼接【创建日期】 20191128 by wangxioabei【修改日期】 NOTE.1: """def CutVideoFromFile(video_file_name,windows_name = 'videoShowing'): cap = cv2.VideoCapture(video_file_name) # 打开视频文件 # 需要明确视频保存的格式 fourcc = cv2.VideoWriter_fourcc(*'XVID') fps = cap.get(cv2.CAP_PROP_FPS) print('帧率:%d'%fps) size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)),int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))) out = cv2.VideoWriter('BeltTear.avi',fourcc,fps, size) SaveTime = [[38*60+38,39*60+59],[42*60+54,44*60+11],[47*60+8,48*60+24],[51*60+20,52*60+39]] print(SaveTime[0][0]) now_frame = 0 while (cap.isOpened()): ret, frame = cap.read() # 捕获一帧图像 img_h, img_w, img_ch = frame.shape # print(frame.shape) if ret: # 【1】 不能直接将灰度或二值化的图片保存成视频,需要转换成彩色 if img_ch==1: frame = cv2.cvtColor(frame, cv2.COLOR_GRAY2BGR) # cv2.imshow(windows_name, frame) for i in range(len(SaveTime)): if now_frame > SaveTime[i][0]*fps and now_frame < SaveTime[i][1]*fps: out.write(frame) print(now_frame) now_frame += 1 if now_frame > SaveTime[2][1]*fps: break; k = cv2.waitKey(1) & 0xFF if k == 27: break # cv2.waitKey(25) else: break cap.release() out.release() cv2.destroyAllWindows()其中SaveTime列表 中嵌套的列表为截取视频的时间s,也可以将其当做参数传入,即可封装整个函数。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.安装Opencv包pipinstallopvencv-python2.实现代码: 视频转为图片:importcv2cap=cv2.VideoCapture
本文实例为大家分享了Python基于OpenCV实现人脸检测,并保存的具体代码,供大家参考,具体内容如下安装opencv如果安装了pip的话,Opencv的在w
本篇博客介绍利用python脚本实现视频分帧,并将每一帧保存到本地。主要基于opencv包来实现,在运行代码前确保opencv包已正确安装。下面是主要代码:im
使用python3+opencv3.3.1环境将视频流保存为本地视频文件,具体内容如下1、利用opencv中的VideoCapture类获取视频流的链接,通过c
利用Python+opencv实现从摄像头捕获图像,识别其中的人眼/人脸,并打上马赛克。系统环境:Windows7+Python3.6.3+opencv3.4.