Opencv-Python(二) 读取, 写入/出视频

2024-04-28 06:18

本文主要是介绍Opencv-Python(二) 读取, 写入/出视频,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注:如果运行本文中的代码遇到视频无法读取,写出的问题请参考这篇文章的第二大部分的第五第六步

VedioCapture(fileename)–视频读取

使用如下代码可以创建一个名为vedioCapture的opencv2的视频处理句柄(打开视频文件)

videoCapture = cv2.VideoCapture('1.mp4')

参数为视频的名字(或者路径+名字)注意单引号。当使用的参数为一个数字0的时候代表从摄像头获取视频。

videoCapture = cv2.VideoCapture(0)

创建了这个句柄之后可以使用如下语句读取视频的下一帧,第一个返回值为是否成功获取视频帧,第二个返回值为返回的视频帧。

success, frame = videoCapture.read()

使用如下语句可以获得视频文件的属性fps以及size

fps = videoCapture.get(cv2.cv.CV_CAP_PROP_FPS)
size = (int(videoCapture.get(cv2.cv.CV_CAP_PROP_FRAME_WIDTH)),int(videoCapture.get(cv2.cv.CV_CAP_PROP_FRAME_HEIGHT)))

cv2.VideoWriter(filename, fourcc, fps, framesize, isColor)–视频写入/出

使用这个函数可以创建一个用于写出视频文件的句柄,第一个参数为写出的视频文件的名字/路径,第二个参数为写出视频的编码格式,第三个参数为写出视频的fps值,第四个参数为写出视频的画面大小,最后一个参数为设置写出视频是否为彩色视频,可以省略,默认为彩色。
其中第二个参数可以选取以下值(分别对应不同的编码方式):

cv2.cv.CV_FOURCC('P', 'I', 'M', '1') = MPEG-1 codec
cv2.cv.CV_FOURCC('M', 'J', 'P', 'G') = motion-jpeg codec
cv2.cv.CV_FOURCC('M', 'P', '4', '2') = MPEG-4.2 codec
cv2.cv.CV_FOURCC('D', 'I', 'V', '3') = MPEG-4.3 codec
cv2.cv.CV_FOURCC('D', 'I', 'V', 'X') = MPEG-4 codec
cv2.cv.CV_FOURCC('U', '2', '6', '3') = H263 codec
cv2.cv.CV_FOURCC('I', '2', '6', '3') = H263I codec
cv2.cv.CV_FOURCC('F', 'L', 'V', '1') = FLV1 codec
videoWriter = cv2.VideoWriter('oto_other.avi', cv2.cv.CV_FOURCC('X', '2', '6', '4'), fps, size)

这里创建了一个名为videoWriter的句柄,写出文件指向“oto_other.avi”,编码方式为x264,fps和size和之前读入的视频一致。
创建完句柄之后使用如下语句即可向视频文件中写出一帧视频

videoWriter.write(frame)  # write one frame into the output video

使用的所有代码如下:

只需要在文件所在的目录下放一个名为1.mp4的视频文件,运行这个文件即可播放并复制这个视频到一个名为oto_other.avi的文件。

# -*- coding: utf-8 -*-
# =================================================================
# windows10, PyCharm, anaconda2, python 2.7.13, opencv 2.4.13
# 2017-12-17
# powered by tuzixini
# attention: you might need install the encoder fist, like x264vfw
# =================================================================import cv2  # import opencv# use opencv open the video 1.mp4
videoCapture = cv2.VideoCapture('1.mp4')
# get the inf of vedio,fps and size
fps = videoCapture.get(cv2.cv.CV_CAP_PROP_FPS)
size = (int(videoCapture.get(cv2.cv.CV_CAP_PROP_FRAME_WIDTH)),int(videoCapture.get(cv2.cv.CV_CAP_PROP_FRAME_HEIGHT)))# point out how to encode videos
# I420-avi=>cv2.cv.CV_FOURCC('X','2','6','4');
# MP4=>cv2.cv.CV_FOURCC('M', 'J', 'P', 'G')
# The mp4 encoder in my computer do not work,so i just use X264
videoWriter = cv2.VideoWriter('oto_other.avi', cv2.cv.CV_FOURCC('X', '2', '6', '4'), fps, size)
# read one frame from the video
success, frame = videoCapture.read()
while success:cv2.imshow("Oto Video", frame)  # display this framecv2.waitKey(int(fps))  # delayvideoWriter.write(frame)  # write one frame into the output videosuccess, frame = videoCapture.read()  # get the next frame of the video
# some process after finish all the program
cv2.destroyAllWindows()     # close all the widows opened inside the program
videoCapture.release        # release the video read/write handler
videoWriter.release

这篇关于Opencv-Python(二) 读取, 写入/出视频的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942485

相关文章

Python数独游戏

数独(Sudoku)是一种逻辑性的数字填充游戏,玩家需要在一个分为九宫的81格网格上填入数字,同时满足每一行、每一列以及每个宫(3x3的子网格)的数字都不重复。 在Python中实现一个数独游戏可以涉及到多个方面,包括生成数独谜题、检查输入的有效性、解决数独谜题等。以下是一个简单的数独游戏的实现示例,包括生成随机数独和解决数独的基本逻辑: 1. 生成随机数独 import randomdef

Python---NumPy万字总结【此篇文章内容难度较大,线性代数模块】(3)

NumPy的应用(3) 向量 向量(vector)也叫矢量,是一个同时具有大小和方向,且满足平行四边形法则的几何对象。与向量相对的概念叫标量或数量,标量只有大小,绝大多数情况下没有方向。我们通常用带箭头的线段来表示向量,在平面直角坐标系中的向量如下图所示。需要注意的是,向量是表达大小和方向的量,并没有规定起点和终点,所以相同的向量可以画在任意位置,例如下图中 w \boldsymbol{w} w和

视频拼接融合产品的产品与架构设计(三)内存和显存单元数据迁移

上一篇文章 视频拼接融合产品的产品与架构设计(二) 这一篇沉下先来,彻底放弃了界面,界面最终的体现是最后要做的,现在要做的是产品的架构,使用链式架构方式迁移数据。同时增加插件口,方便编程序。 插件架构 为了视频拼接和算法等的产品化,在视频解码前(录像),解码后在gpu,解码后转颜色空间(bgr),解码后算法处理,解码后算法处理下放部分数据到cpu(如截图),解码后算法处理后转颜色空间,框架必

python EEL应用程序的启动过程

EEL 启动流程 初始化 EEL (eel.init()): 设定静态文件目录,通常是包含 HTML、CSS、JavaScript 等文件的目录。扫描指定目录下的 JavaScript 文件,寻找通过 eel.expose() 暴露的函数。 启动 Web 服务器 (eel.start()): 基于 Bottle 框架启动一个轻量级的 Web 服务器。服务器配置默认主页和静态资源的服务。 创

python词云图形状修改

python词云图形状修改 词云图介绍wordcloud介绍修改形状参数效果代码 词云图介绍 词云图(Word Cloud)是一种文本数据的可视化表示形式,它通过字体大小、颜色、布局等视觉元素来展示文本中不同词汇的频率或重要性。词云图中,出现频率高的词汇会被赋予较大的字体,从而突出显示;而频率较低的词汇则使用较小的字体。这种可视化方式有助于快速识别文本中的关键信息,发现文本的主题

数字水印 | Arnold 变换的 Python 代码实现

🥭 参考博客: Arnold 阿诺德置乱(猫脸变换)图像盲水印注入预处理(Python) 1 回顾:Arnold 公式 A r n o l d \mathsf{Arnold} Arnold 变换公式如下: [ x n + 1 y n + 1 ] = [ 1 b a a b + 1 ] [ x n y n ] m o d ( N ) \begin{bmatrix} x_{n+1}

微信小程序毕业设计-基于Java后端的微信小程序源码150套(附源码+数据库+演示视频+LW)

大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。 🧡今天给大家分享150的微信小程序毕业设计,后台用Java开发,这些项目都经过精心挑选,涵盖了不同的实战主题和用例,可做毕业设计和课程设计参考。 ✍️除了源码,对于大部分项目实现的功能都有相应的介绍,并且配有演示视频,方便大家根据自己的需要择优下载学习。 💂另外如有定制需求或者想要相对应的论文参考,文末可以十我VX联系。 🤝后续还会

浅谈java,python,c++的差异

Java,Python和C++是三种常见的编程语言,它们在很多方面有着不同的特点。以下是它们的一些主要异同点: 宏观应用 语法和风格: Java:Java是一种静态类型语言,语法相对严谨,需要显式声明变量的类型。Java通常被用于大型企业应用程序开发。Python:Python是一种动态类型语言,语法简洁清晰,被称为“优雅的编程语言”。Python适合快速开发原型和小型项目。C++:C++是

python智能电力监控与资费电费缴纳管理系统vue+django

本系统的设计与实现共包含6个表:分别是配置文件信息表,电力记录信息表,故障报修信息表,缴费订单信息表,用户表信息表,用户信息表, 本文所设计的电费缴纳系统的设计与实现拥有前端和后端,前端使用Vue.js框架和创建,后端使用python语言的django框架创建,使用Mysql数据库对后台数据进行存储。将pycharm作为主要的开发工具。接着进行系统的需求分析、功能设计、数据库设计,最后进行编码实

【opencv】图像处理(二)

前文指引 一、使用到的图片 一、梯度计算 原始图片 img = cv2.imread('circle.jpg')plt.imshow(img)plt.show() sobel算子 使用两个核 Gx = [[-1,0,1], [-2,0,2], [-1,0,1]] Gy = [[-1,-2,-1], [0,0,0], [