import osimport cv2 import timedef on_mouse(event,x,y, flag, para):global status_value, start_frame, end_frame, timesif event == cv2.EVENT_LBUTTONDOWN: # 鼠标左键点击times += 1status_value = not status_valueif status_value:start_frame = frame_number# print(f"Start frame: {start_frame}")else:split_flag = 'd' + str(int(times/2))# print('split_flag: ', split_flag)end_frame = frame_number# print(f"End frame: {end_frame}")extract_and_save_video(split_flag,para[0], para[1])def extract_and_save_video(split_flag, folder, video_name):now_time = time.time()print('now_time:', now_time)out = cv2.VideoWriter('{}_{}_{}.avi'.format(video_name, folder, split_flag), cv2.VideoWriter.fourcc(*'XVID'), fps, size)print('start frame: {}'.format(start_frame))print('end frame: {}'.format(end_frame))for i in range(start_frame, end_frame + 1):cap.set(cv2.CAP_PROP_POS_FRAMES, i)ret, frame = cap.read()if ret:out.write(frame)out.release()print('video saved *********************')cv2.waitKey(5000)videos_folder = 'E:\\河南深丛信息科技\\datasets\\record_night'action_folders = os.listdir(videos_folder)[:2] for folder in action_folders:video_folder = os.path.join(videos_folder, folder)video_files = os.listdir(video_folder)for video_file in video_files:video_name = video_file.split('.mkv')[0]video_file_path = os.path.join(video_folder, video_file)print('video file path:', video_file_path)cap = cv2.VideoCapture(video_file_path)fps = cap.get(cv2.CAP_PROP_FPS)print('fps: {}'.format(fps))frame_count = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))print("frame_count:", frame_count)status_value = 0# 初始化变量start_frame = Noneend_frame = Noneframe_number = 0times = 0event = 0size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)),int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)))while True:ret, frame = cap.read()if not ret:breakframe_number += 1cv2.imshow('Video', frame)cv2.setMouseCallback('Video', on_mouse, [folder, video_name])if frame_number == 1:cv2.waitKey(3000)if cv2.waitKey(50) & 0xFF == ord('q'):breakcap.release()cv2.destroyAllWindows()print(video_file + ' is done......\n')cv2.waitKey(3000)
python opencv 持续点选开始帧,结束帧,切割视频成几个小段
2024/10/24 13:28:35
来源:https://blog.csdn.net/DeepCBW/article/details/139932258
浏览:
次
关键词:python opencv 持续点选开始帧,结束帧,切割视频成几个小段
版权声明:
本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。
我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com
热文排行
- 《警世贤文》摘抄:处人篇、受恩篇、宽人篇、听劝篇、劝善篇(多读书、多看报、少吃零食多睡觉)
- nccl 03 记 回顾:从下载,编译到调试 nccl-test
- 【CVE-2024-38077】核弹级Windows RCE漏洞如何自检并修复该漏洞(附批量漏洞检测工具及分析伪代码)
- 【HW必备】用友NC-Cloud存在17处漏洞合集
- Vmess协议是什么意思? VLESS与VMess有什么区别?
- AD24设计步骤
- ctfshow-web入门-php特性(web132-web136)
- HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 单选题序号4
- windows11 ,ubuntu20.04双系统,ubuntu没有wifi的解决方式
- [python][whl]causal-conv1d的python模块在windows上whl文件下载
最新新闻
- python opencv 持续点选开始帧,结束帧,切割视频成几个小段
- ROS2进阶 -- 硬件篇第五章第三节 -- PlateFormIO使用开源库驱动IMU——MPU6050
- 设计模式实战:库存管理系统的设计与实现2
- 用ESP32IDF 新版本5.3.0读写16口输入或者输出PCF8575程序编写
- 18 - 各赛事的用户注册率(高频 SQL 50 题基础版)
- 四种跨域解决方案
- CI/CD——CI持续集成实验
- 【golang】go语言读取Excel表格中的数据
- Eureka 原理与实践详解:深入理解与代码分析
- OnnxRuntime部署LivePortrait实现快速、高质量的人像驱动视频生成
推荐新闻
- python opencv 持续点选开始帧,结束帧,切割视频成几个小段
- ROS2进阶 -- 硬件篇第五章第三节 -- PlateFormIO使用开源库驱动IMU——MPU6050
- 设计模式实战:库存管理系统的设计与实现2
- 用ESP32IDF 新版本5.3.0读写16口输入或者输出PCF8575程序编写
- 18 - 各赛事的用户注册率(高频 SQL 50 题基础版)
- 四种跨域解决方案
- CI/CD——CI持续集成实验
- 【golang】go语言读取Excel表格中的数据
- Eureka 原理与实践详解:深入理解与代码分析
- OnnxRuntime部署LivePortrait实现快速、高质量的人像驱动视频生成