python读取视频显示视频和保存视频文件
2015-12-12 15:56
676 查看
为了获取视频,应该创建一个
VideoCapture 对象。他的参数可以是设备的索引号,或者是一个视频文件。设备索引号就是在指定要使用的摄像头。
一般的笔记本电脑都有内置摄像头。所以参数就是
0。你可以通过设置成
1 或者其他的来选择别的摄像头。之后,你就可以一帧一帧的捕获视频了。但是最后,别忘了停止捕获视频。
与c++很类似
cap.read()
返回一个布尔值(True/False)。如果帧读取的是正确的,就是
True。
所以最后你可以通过检查他的返回值来查看视频文件是否已经到了结尾。
有时
cap 可能不能成功的初始化摄像头设备。这种情况下上面的代码会报错。你可以使用
cap.isOpened(),来检查是否成功初始化了。如果返回值是True,那就没有问题。否则就要使用函数
cap.open()。
你可以使用函数
cap.get(propId)
来获得视频的一些参数信息。这里propId
可以是 0
到 18
之间的任何整数。每一个数代表视频的一个属性其中的一些值可以使用 cap.set(propId,value)
来修改,
value 就是你想要设置成的新值。例如,我可以使用
cap.get(3) 和
cap.get(4) 来查看每一帧的宽和高。默认情况下得到的值是
640X480。但是我可以使用
ret=cap.set(3,320)和
ret=cap.set(4,240) 来把宽和高改成
320X240。
2、保存视频
在我们捕获视频,并对每一帧都进行加工之后我们想要保存这个视频。对
于图片来时很简单只需要使用 cv2.imwrite()。但对于视频来说就要多做点工
作。
这次我们要创建一个
VideoWriter
的对象。我们应该确定一个输出文件的名字。接下来指定
FourCC
编码。播放频率和帧的大小也都需要确定。最后一个是
isColor
标签。如果是 True,每一帧就是彩色图,否则就是灰度图。FourCC
就是一个
4 字节码,用来确定视频的编码格式。可用的编码列表可以从fourcc.org查到。这是平台依赖的。下面这些编码器对我来说是有用个。
•
In Fedora: DIVX, XVID, MJPG, X264, WMV1, WMV2. (XVID is
more preferable. MJPG results in high size video. X264 gives
very small size video)
• In Windows: DIVX (More to be tested and added)
• In OSX : (I don’t have access to OSX. Can some one fill this?)
FourCC 码以下面的格式传给程序,以
MJPG 为例:
cv2.cv.FOURCC('M','J','P','G')
或者 cv2.cv.FOURCC(*'MJPG')。
下面的代码是从摄像头中捕获视频,沿水平方向旋转每一帧并保存它。
VideoCapture 对象。他的参数可以是设备的索引号,或者是一个视频文件。设备索引号就是在指定要使用的摄像头。
一般的笔记本电脑都有内置摄像头。所以参数就是
0。你可以通过设置成
1 或者其他的来选择别的摄像头。之后,你就可以一帧一帧的捕获视频了。但是最后,别忘了停止捕获视频。
import numpy as np import cv2 cap=cv2.VideoCapture(0) while (True): ret,frame=cap.read() gray=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY) cv2.imshow("shiyan",gray) if cv2.waitKey(1)&0xFF==ord('q'): break cap.release() cv2.destroyAllWindows()
与c++很类似
cap.read()
返回一个布尔值(True/False)。如果帧读取的是正确的,就是
True。
所以最后你可以通过检查他的返回值来查看视频文件是否已经到了结尾。
有时
cap 可能不能成功的初始化摄像头设备。这种情况下上面的代码会报错。你可以使用
cap.isOpened(),来检查是否成功初始化了。如果返回值是True,那就没有问题。否则就要使用函数
cap.open()。
你可以使用函数
cap.get(propId)
来获得视频的一些参数信息。这里propId
可以是 0
到 18
之间的任何整数。每一个数代表视频的一个属性其中的一些值可以使用 cap.set(propId,value)
来修改,
value 就是你想要设置成的新值。例如,我可以使用
cap.get(3) 和
cap.get(4) 来查看每一帧的宽和高。默认情况下得到的值是
640X480。但是我可以使用
ret=cap.set(3,320)和
ret=cap.set(4,240) 来把宽和高改成
320X240。
2、保存视频
在我们捕获视频,并对每一帧都进行加工之后我们想要保存这个视频。对
于图片来时很简单只需要使用 cv2.imwrite()。但对于视频来说就要多做点工
作。
这次我们要创建一个
VideoWriter
的对象。我们应该确定一个输出文件的名字。接下来指定
FourCC
编码。播放频率和帧的大小也都需要确定。最后一个是
isColor
标签。如果是 True,每一帧就是彩色图,否则就是灰度图。FourCC
就是一个
4 字节码,用来确定视频的编码格式。可用的编码列表可以从fourcc.org查到。这是平台依赖的。下面这些编码器对我来说是有用个。
•
In Fedora: DIVX, XVID, MJPG, X264, WMV1, WMV2. (XVID is
more preferable. MJPG results in high size video. X264 gives
very small size video)
• In Windows: DIVX (More to be tested and added)
• In OSX : (I don’t have access to OSX. Can some one fill this?)
FourCC 码以下面的格式传给程序,以
MJPG 为例:
cv2.cv.FOURCC('M','J','P','G')
或者 cv2.cv.FOURCC(*'MJPG')。
下面的代码是从摄像头中捕获视频,沿水平方向旋转每一帧并保存它。
import numpy as np import cv2 cap = cv2.VideoCapture(0) # Define the codec and create VideoWriter object fourcc = cv2.cv.FOURCC(*'XVID') out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480)) while (cap.isOpened()): ret,frame=cap.read() if ret==True: frame=cv2.flip(frame,0) out.write(frame) cv2.imshow("实验",frame) if cv2.waitKey(0)&0xFF==ord('q'): break else: break cap.release() out.release() cv2.destroyAllWindows()
相关文章推荐
- Python基础(面向对象之类成员与修饰符)
- numpy各函数简介之生成数组函数
- 编译python3
- python 用xlrd及xlutils模块 复制excel文件
- python把文件夹/子文件夹内的图片导到指定文件夹
- Python模块学习系列(4)----matplotlib
- Python快速入门笔记
- 机器学习&深度学习实践(Python版)----Multivariate Linear Regression(多元线性回归)
- python json
- 机器学习算法与Python实践之(七)逻辑回归(Logistic Regression)
- 机器学习算法与Python实践之(六)二分k均值聚类
- 机器学习算法与Python实践之(五)k均值聚类(k-means)
- 机器学习算法与Python实践之(四)支持向量机(SVM)实现
- 机器学习算法与Python实践之(三)支持向量机(SVM)进阶
- 机器学习算法与Python实践之(二)支持向量机(SVM)初级
- 机器学习算法与Python实践之(一)k近邻(KNN)
- python拾遗(二) python语法
- Python: scikit-image Blob detection
- Python: scikit-image 彩色图像滤波
- 零基础入门学习Python(8):字符串格式化