Python_OpenCV视频截取并保存
在图像处理之前,我们需要对拿到手的数据进行筛选,对于视频,我们需要从中截取我们需要的一段或几段
整体思路比较简单,通过设定截取视频的起止时间(帧数),可以将该时间段内的图像保存为新的视频
直接上代码:
""" 【函数名称】 13 截取视频 【参数】 输入参数 视频文件名称 【详细介绍】 输入不同时间段 进行截取拼接 【创建日期】 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,也可以将其当做参数传入,即可封装整个函数。
posted on 2019-11-28 17:46 wangxiaobei2019 阅读(5106) 评论(0) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?