OpenCV技术应用(8)— 如何将视频分解

**前言:****Hello大家好,我是小哥谈。**本节课就手把手教大家如何将一幅图像转化成热力图,希望大家学习之后能够有所收获~!🌈

目录

🚀1.技术介绍

🚀2.实现代码

🚀1.技术介绍

视频是由大量的帧组成的。其中,每一帧都是一幅图像。所谓视频分解,就是把组成视频的每一帧从视频文件中分解出来。本案例将使用OpenCV分解一个视频文件,把分解得到的视频帧保存在如图所示的images文件夹下。

在保存视频帧之前,要先命名将要被保存的视频帧。关键代码如下所示:

python 复制代码
frame_name = 1 # 使用数字命名将要被保存的帧

具备了这个标签后,再来编写"将这些视频帧保存在images文件夹下"的代码。需要注意的是,在拼接保存视频帧路径之前,要先把frame_name由整数转为字符串。关键代码如下所示:

python 复制代码
cv2.imwrite("images/" + str(frame_name) + ".jpg", frame) # 保存视频帧

🚀2.实现代码

本案例的操作对象是视频文件。首先,使用VideoCapture类的构造方法打开视频文件。然后,读取视频帧。接着,把读取到的视频帧保存在images文件夹下。最后,释放被视频文件占用的空间。

具体的实现代码如下所示:

python 复制代码
import cv2

video = cv2.VideoCapture(r"C:\Users\Lenovo\Desktop\room.mp4") # 打开视频文件
frame_name = 1 # 使用数字命名将要被保存的帧
while (video.isOpened()): # 视频文件被打开后
    retval, frame = video.read() # 读取视频帧
    if retval == True: # 读取到视频帧后
        cv2.imwrite("data/images/" + str(frame_name) + ".jpg", frame) # 保存视频帧
    else: # 没有读取到视频帧
        break # 终止循环
    frame_name = frame_name + 1 # 用于命名将要被保存的帧的数字执行自加操作
    cv2.waitKey(1) # 1毫秒后播放视频文件的下一帧
print("视频已分解完成!") # 控制台输出提示信息
video.release() # 释放被视频文件占用的空间

运行结果如下所示:


相关推荐
Faker66363aaa5 小时前
如何使用RetinaNet进行中式菜品识别分类训练使用菜谱数据集炒菜,炖汤,蒸鱼,凉拌,烧烤,煎炸
人工智能·分类·数据挖掘
I Promise345 小时前
BEV视角智驾方案全维度发展梳理
人工智能·算法·计算机视觉
woshikejiaih6 小时前
2026年阅读软件Top5避坑攻略:告别卡顿闪退提升沉浸感
人工智能·python
KG_LLM图谱增强大模型6 小时前
SCHEMA-MINERpro:基于智能体AI的本体映射框架——在人机协作工作流中通过大模型发现科学新模式
数据库·人工智能
小草cys6 小时前
opencode/claude code自动写书啦
人工智能·自动化·大模型
MoonOutCloudBack6 小时前
VeRL 框架 RL 微调大语言模型,algorithm.use_pf_ppo 参数详解
人工智能·机器学习·语言模型·自然语言处理
hhzz7 小时前
【Vision人工智能设计 】Wan(万相) 内容创作平台与能力
人工智能·阿里·视觉大模型·wan·万相
黑巧克力可减脂7 小时前
Vibe Coding重构CRM:以AI编程之术,破传统管理之困,承革新致远之道
人工智能·重构·软件工程·ai编程
wuxi_joe7 小时前
工业信息化与AI:制造业配置能力的重构
人工智能·重构
heimeiyingwang7 小时前
从 0 到 1:企业 AI 战略规划与落地路线图
大数据·人工智能