时间:2021-05-22
使用python3+opencv3.3.1环境将视频流保存为本地视频文件,具体内容如下
1、利用opencv中的VideoCapture类获取视频流的链接,通过cv2的方法得到该视频流的帧数和每帧大小。
2、使用VideoWriter类进行视频编码
3、通过VideoCapture的read()方法进行视频流解码成每一帧
4、获取到每一帧frame,我们就可以对该帧做图像算法(例如识别、图像加强、灰度变换等)
import cv2 from matplotlib import pyplot as plt #通过cv2中的类获取视频流操作对象cap cap = cv2.VideoCapture('rtsp://admin:passwd@10.130.10.111:554/MPEG-4/ch1/main/av_stream') #调用cv2方法获取cap的视频帧(帧:每秒多少张图片) fps = cap.get(cv2.CAP_PROP_FPS) print(fps) #获取cap视频流的每帧大小 size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)), int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))) print(size) #定义编码格式mpge-4 fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', '2') #定义视频文件输入对象 outVideo = cv2.VideoWriter('saveDir.avi',fourcc,fps,size) #获取视频流打开状态 if cap.isOpened(): rval,frame = cap.read() print('ture') else: rval = False print('False') tot=1 c=1 #循环使用cv2的read()方法读取视频帧 while rval: rval,frame = cap.read() cv2.imshow('test',frame) #每间隔20帧保存一张图像帧 # if tot % 20 ==0 : # cv2.imwrite('cut/'+'cut_'+str(c)+'.jpg',frame) # c+=1 tot+=1 print('tot=',tot) #使用VideoWriter类中的write(frame)方法,将图像帧写入视频文件 outVideo.write(frame) cv2.waitKey(1) cap.release() outVideo.release() cv2.destroyAllWindows()结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们在做好视频文件后,要对文件进行保存,保存为我们需要的视频格式,那么,如果才能生成视频呢,在这里给大家介绍一下,AE如何进行渲染生成视频文件。软件名称:Aft
Python3将数据保存为txt文件的方法,具体内容如下所示:f=open("data/model_Weight.txt",'a')#若文件不存在,系统自动创建
以MicrosoftOfficePowerPoint为例,其嵌入本地视频和链接本地视频的区别在于视频文件保存方式不同。 MicrosoftOfficePowe
利用premiere处理视频素材,想将视频中的声音导出保存、另作他用,该如何实现呢?下文介绍使用premiere导出视频声音保存为MP3文件的方法,感兴趣的朋友
aegisub字幕和视频合并的方法是: 1、打开字幕软件点击文件,点击保存为字幕; 2、点击保存; 3、然后先把制作好的字幕导入软件,拖入等于导入,字幕无