如何在视频中提取关键帧?
在视频处理中,提取关键帧是一项常见的任务。下面将介绍如何基于FFmpeg和Python,结合OpenCV库来实现从视频中提取关键帧的功能。
实现思路
- 使用FFmpeg获取视频的关键帧时间戳:FFmpeg是一个强大的视频处理工具,可以通过命令行获取视频中关键帧的时间戳信息。
- 使用OpenCV根据时间戳提取关键帧:OpenCV是一个广泛使用的计算机视觉库,可以根据视频的时间戳读取相应的帧。
代码实现
import cv2
import subprocess
import redef get_keyframe_timestamps(video_path):"""使用FFmpeg获取视频中关键帧的时间戳:param video_path: 视频文件的路径:return: 关键帧的时间戳列表"""# 构建FFmpeg命令command = ['ffmpeg','-i', video_path,'-skip_frame', 'nokey','-vsync', '0','-frame_pts', '1','-loglevel', 'verbose','-f', 'image2','-']try:# 执行FFmpeg命令并捕获输出result = subprocess.run(command, capture_output=True, text=True, check=True)output = result.stderr# 使用正则表达式提取关键帧的时间戳timestamps = re.findall(r'pts_time:([\d.]+)', output)timestamps = [float(ts) for ts in timestamps]return timestampsexcept subprocess.CalledProcessError as e:print(f"FFmpeg命令执行出错: {e.stderr}")return []def extract_keyframes(video_path, output_folder):"""根据关键帧的时间戳提取关键帧并保存到指定文件夹:param video_path: 视频文件的路径:param output_folder: 保存关键帧的文件夹路径"""# 打开视频文件cap = cv2.VideoCapture(video_path)if not cap.isOpened():print("无法打开视频文件")return# 获取关键帧的时间戳timestamps = get_keyframe_timestamps(video_path)for i, ts in enumerate(timestamps):# 设置视频的播放位置到关键帧的时间戳cap.set(cv2.CAP_PROP_POS_MSEC, ts * 1000)ret, frame = cap.read()if ret:# 保存关键帧到指定文件夹output_path = f"{output_folder}/keyframe_{i}.jpg"cv2.imwrite(output_path, frame)print(f"保存关键帧 {output_path}")# 释放视频捕获对象cap.release()if __name__ == "__main__":video_path = "your_video.mp4" # 替换为实际的视频文件路径output_folder = "keyframes" # 替换为实际的输出文件夹路径extract_keyframes(video_path, output_folder)
代码解释
-
get_keyframe_timestamps函数:- 使用FFmpeg命令获取视频中关键帧的时间戳信息。
- 通过正则表达式从FFmpeg的输出中提取关键帧的时间戳。
-
extract_keyframes函数:- 打开视频文件。
- 调用
get_keyframe_timestamps函数获取关键帧的时间戳。 - 根据时间戳设置视频的播放位置,并读取关键帧。
- 将关键帧保存到指定的文件夹中。
使用方法
- 确保已经安装了FFmpeg和OpenCV库。
- 将代码中的
video_path替换为实际的视频文件路径。 - 将代码中的
output_folder替换为实际的输出文件夹路径。 - 运行代码,即可从视频中提取关键帧并保存到指定文件夹。
注意事项
- 请确保FFmpeg的可执行文件已经添加到系统的环境变量中,否则可能会出现命令执行失败的问题。
- 提取的关键帧将以
keyframe_0.jpg,keyframe_1.jpg, … 的格式保存到指定的文件夹中。
相关文章:
如何在视频中提取关键帧?
在视频处理中,提取关键帧是一项常见的任务。下面将介绍如何基于FFmpeg和Python,结合OpenCV库来实现从视频中提取关键帧的功能。 实现思路 使用FFmpeg获取视频的关键帧时间戳:FFmpeg是一个强大的视频处理工具,可以通过命令行获取…...
為什麼使用不限量動態住宅IP採集數據?
在瞭解“不限量動態住宅IP數據採集”之前,我們需要先搞清楚什麼是“動態住宅IP”。簡單來說,動態IP是一種會定期變化的IP地址,通常由互聯網服務提供商(ISP)分配給家庭用戶。與固定IP(靜態IP)不同…...
Go语言中使用viper绑定结构体和yaml文件信息时,标签的使用
在Go中使用Viper将YAML配置绑定到结构体时,主要依赖 mapstructure 标签(而非 json 或 yaml 标签)实现字段名映射。 --- ### 1. **基础绑定方法** 使用 viper.Unmarshal(&config) 或 viper.UnmarshalKey("key", &subConfi…...
OpenIPC开源FPV之Adaptive-Link安装
OpenIPC开源FPV之Adaptive-Link安装 1. 源由2. 介绍2.1 天空端安装2.2 地面端安装 3. 问题汇总3.1 安装脚本问题3.2 网络安装问题3.3 非SSC30KQ/SSC338Q硬件3.4 代码疑问 4. 总结5. 后续 1. 源由 鉴于飞行过程,发现一些马赛克现象,且60FPS桌面30FPS的录…...
[杂学笔记]OSI七层模型作用、HTTP协议中的各种方法、HTTP的头部字段、TLS握手、指针与引用的使用场景、零拷贝技术
1.OSI七层模型作用 物理层:负责光电信号的传输,以及将光电信号转化为二进制数据数据链路层:主要负责将收到的二进制数据进一步的封装为数据帧报文。同时因为数据在网络中传递的时候,每一个主机都能够收到报文数据,该层…...
RK3568开发笔记-AD7616调试笔记
目录 前言 一、AD7616介绍 高分辨率 高速采样速率 宽模拟输入范围 集成丰富功能 二、原理图连接 三、设备树配置 四、内核驱动配置 五、AD芯片测试 总结 前言 在嵌入式数据采集领域,将模拟信号精准转换为数字信号至关重要。AD7616 作为一款性能卓越的 16 位模数转换器…...
Unity摄像机与灯光相关知识
一、Inspector窗口 Inspector窗口可以查看和编辑对象的属性以及设置 其中包含各种组件,例如用Cube对象来举例 1.Sphere(Mesh)组件: 用来决定对象的网格属性,例如球体网格为Sphere、立方体网格为Cube 2.Mesh Renderer组件: 用来设置…...
AI前端革新金融风控:ScriptEcho助力高效开发
1. 引言:金融风控的挑战与前端效率需求 在当今快速变化的金融环境中,风险评估和反欺诈已成为金融机构运营的核心。金融风控不仅关乎企业的盈利能力,更直接影响着整个金融体系的稳定。一个强大的风控系统需要能够实时监控、分析并预测潜在的风…...
STM32--SPI通信讲解
前言 嘿,小伙伴们!今天咱们来聊聊STM32的SPI通信。SPI(Serial Peripheral Interface)是一种超常用的串行通信协议,特别适合微控制器和各种外设(比如传感器、存储器、显示屏)之间的通信。如果你…...
CryptoJS库中WordArray对象支持哪些输出格式?除了toString() 方法还有什么方法可以输出吗?WordArray对象的作用是什么?
前言:这里只说js用的CryptoJS库里的相关内容,只用js来进行代码操作和讲解。 这里网上相关的帖子很少,不得已问了很长时间AI 想引用CryptoJS库情况分两种,一种是html引用,另一种是在Nodejs里引用。 一、引用CryptoJS库…...
第六次作业
一.对比 LVS 负载均衡群集的 NAT 模式和 DR 模式,比较其各自的优势 。 LVS-NAT模式的优势 配置简单:NAT模式的配置相对容易,无需复杂的网络设置,适合初学者和小型网络环境。 网络架构灵活:由于使用了NAT技术…...
八、Spring Boot:RESTful API 应用
创建第一个 Spring Boot RESTful API 应用 在现代 Web 开发中,RESTful API 是一种非常流行的设计风格,它基于 HTTP 协议,提供了简单、灵活的方式来构建网络应用。Spring Boot 作为一款强大的微服务框架,提供了丰富的工具和支持&a…...
Pytorch实现之混合成员GAN训练自己的数据集
简介 简介:提出一种新的MMGAN架构,使用常见生成器分布的混合对每个数据分布进行建模。由于生成器在多个真实数据分布之间共享,高度共享的生成器(通过混合权重反映)捕获分布的公共方面,而非共享的生成器捕获独特方面。 论文题目:MIXED MEMBERSHIP GENERATIVE ADVERSARI…...
微信小程序网络请求与API调用:实现数据交互
在前几篇文章中,我们学习了微信小程序的基础知识、数据绑定、事件处理以及页面导航与路由。这些知识帮助我们构建了具备基本交互功能的小程序。然而,一个完整的应用通常需要与服务器进行数据交互,例如获取用户信息、提交表单数据等。本文将深入探讨微信小程序的网络请求与AP…...
Cramér-Rao界:参数估计精度的“理论底线”
Cramr-Rao界:参数估计精度的“理论底线” 在统计学中,当我们用数据估计一个模型的参数时,总希望估计结果尽可能精确。但精度有没有一个理论上的“底线”呢?答案是有的,这就是Cramr-Rao界(Cramr-Rao Lower …...
nv docker image 下载与使用命令备忘
1,系统需求 Requirements for GPU Simulation GPU Architectures Volta, Turing, Ampere, Ada, Hopper NVIDIA GPU with Compute Capability 7.0 CUDA 11.x (Driver 470.57.02), 12.x (Driver 525.60.13) Supported Systems CPU architectures x86_64, ARM…...
C#连接sql server
连接时,出现如下提示: ERROR [IM014] [Microsoft][ODBC 驱动程序管理器] 在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配 原因是odbc的驱动和应用程序的架构不一致。我的odbc如下所示: 显示为64位,而c#程序显…...
汽车智能制造企业数字化转型SAP解决方案总结
一、项目实施概述 项目阶段划分: 蓝图设计阶段主数据管理方案各模块蓝图设计方案下一阶段工作计划 关键里程碑: 2022年6月6日:项目启动会2022年12月1日:系统上线 二、总体目标 通过SAP实施,构建研产供销协同、业财一…...
vue2项目打包后js文件过大, 首次加载缓慢
vue2项目打包后js文件过大, 首次加载缓慢 安装插件 npm i compression-webpack-plugin6.1.1 -D配置vue.config.js const CompressionWebpackPlugin require(compression-webpack-plugin)module.exports {configureWebpack: {plugins:[new CompressionWebpackPlugin({filen…...
数据安全_笔记系列06:数据生命周期管理(存储、传输、使用、销毁)深度解析
数据安全_笔记系列06:数据生命周期管理(存储、传输、使用、销毁)深度解析 数据生命周期管理(存储、传输、使用、销毁)详解 数据生命周期管理(Data Lifecycle Management, DLM)是围绕数据从创建…...
BP神经网络交叉验证算法与确定最佳隐含层节点数Matlab程序(直接运行、数据Excel格式、...
bp神经网络交叉验证算法和确定最佳隐含层节点个数matlab 程序,直接运行即可。 数据excel格式,注释清楚,效果清晰,一步上手。BP 神经网络交叉验证与隐含层节点自寻优工具包功能说明书一、产品定位本工具包面向“零算法背景”的实验…...
保姆级教程:用ncnn和Android Studio把YOLOv11模型部署到手机上(附完整代码)
从零实现YOLOv11模型在Android端的全流程部署实战 最近在开发一个工业质检应用时,需要将训练好的YOLOv11模型部署到Android设备上。作为移动端AI部署的新手,我花了两周时间才走通整个流程。现在把完整的踩坑经验和优化技巧整理成这份保姆级教程…...
Alacritty Theme主题对比分析:深色vs浅色主题的视觉体验差异
Alacritty Theme主题对比分析:深色vs浅色主题的视觉体验差异 【免费下载链接】alacritty-theme Collection of Alacritty color schemes 项目地址: https://gitcode.com/gh_mirrors/ala/alacritty-theme Alacritty是一款轻量级、高性能的终端模拟器ÿ…...
iPhone弱网环境模拟实战指南
1. iPhone弱网测试的必要性 作为一名移动应用开发者,我深知网络环境对用户体验的影响有多大。在实际开发中,我们经常遇到这样的情况:应用在办公室的Wi-Fi环境下运行流畅,但一到地铁、电梯或者偏远地区就各种卡顿、闪退。这就是为什…...
UML 建模实战指南:从用例图到状态图的完整流程解析
1. UML建模入门:从需求到实现的关键桥梁 第一次接触UML时,我和大多数人一样被那些方框箭头搞得头晕眼花。直到参与电商系统开发,才真正明白这套可视化工具的价值——它就像软件开发界的"施工蓝图",让产品经理、开发人员…...
5个步骤让普通鼠标在macOS上获得超越苹果触控板的体验
5个步骤让普通鼠标在macOS上获得超越苹果触控板的体验 【免费下载链接】mac-mouse-fix Mac Mouse Fix - Make Your $10 Mouse Better Than an Apple Trackpad! 项目地址: https://gitcode.com/GitHub_Trending/ma/mac-mouse-fix 你是否曾经为第三方鼠标在macOS上的糟糕体…...
时间块工作法:编程专注力提升200%
在软件测试领域,专注力是高效工作的核心驱动力。测试从业者常面临多任务切换、需求变更频繁和干扰源众多的挑战,导致注意力分散、效率低下。时间块工作法(Time Blocking)作为一种科学的时间管理策略,通过将工作时间分割…...
ETM vs. Abstract Model: Key Differences and Practical Applications in Hierarchical Design
1. ETM与Abstract Model基础概念解析 在芯片设计领域,随着设计规模越来越大,分层设计流程(hierarchy flow)已经成为主流方法。这种自底向上(bottom-up)的设计方式,先从模块级(block …...
[tomcat最新漏洞20260218] CVE-2026-24734 Apache Tomcat and Tomcat Native - OCSP revocation bypass
文章目录 I 主机漏洞 漏洞描述 漏洞修复建议: Upgrade to Apache Tomcat 9.0.115 or later II 漏洞处理 下载最新版本tomcat 9.0.117 安装最新tomcat III 为了同一个tomcat版本安装多个服务 安装服务 验证服务是否启动成功 迁移配置信息 Tomcat7迁移到Tomcat9 需要删除JasperL…...
实战指南:如何为Windows 7 SP2配置现代硬件支持与安全增强方案
实战指南:如何为Windows 7 SP2配置现代硬件支持与安全增强方案 【免费下载链接】win7-sp2 UNOFFICIAL Windows 7 Service Pack 2, to improve basic Windows 7 usability on modern systems and fully update Windows 7. 项目地址: https://gitcode.com/gh_mirror…...
