python 视频处理,提取视频相关帧,读取Excel

一共这几个模块:

class videoReader 读取视频

class videoFramesExtractor(videoReader):继承了读取视频,主要是用来限制读取视频中的哪些帧,并保存。

read_excel_single(excel_path,event_instance): 处理Excel中的数组,找到事件的帧数范围:

Excel内容是这样的,需要的只是第二列的帧范围,另外第二列中的这些值还有重复的所以需要去除重复:

每一个范围,例如:23450:23461之内的帧要存放在一个文件夹里。

[python] view plain copy

  1. </pre><pre name="code" class="python"># -*- coding: cp936 -*-
  2. import cv2.cv as cv
  3. import os
  4. import cv2
  5. import numpy
  6. import Image
  7. import xlrd
  8. class videoReader:
  9. frame_count=0
  10. def __init__(self,videoPath):
  11. self.videoPath=videoPath
  12. def video_init(self):
  13. self.capture = cv.CaptureFromFile(self.videoPath)
  14. self.win_name = "test"
  15. cv.NamedWindow(self.win_name, cv.CV_WINDOW_AUTOSIZE)
  16. def read(self):
  17. self.video_init()
  18. while 1:
  19. self.frame_count+=1
  20. image = cv.QueryFrame(self.capture )
  21. cv.ShowImage(self.win_name, image)
  22. print self.frame_count
  23. c = cv.WaitKey(10)
  24. if c == 27:
  25. break
  26. cv.DestroyWindow(self.win_name)
  27. class videoFramesExtractor(videoReader):
  28. save_path=‘d:/‘
  29. def __init__(self,videoPath,frameSpan,image_prefix):#image_prefix=event_name
  30. videoReader.__init__(self,videoPath)
  31. self.frameSpan=frameSpan
  32. self.image_prefix=image_prefix
  33. def read(self):
  34. capture = cv2.VideoCapture(self.videoPath)
  35. win_name = "test"
  36. cv.NamedWindow(win_name, cv.CV_WINDOW_AUTOSIZE)
  37. success,frame = capture.read()
  38. init_row=0
  39. while success:
  40. self.frame_count+=1
  41. success,frame = capture.read()
  42. #cv2.imshow(win_name,frame) #显示照片浪费时间
  43. time_duration=self.frameSpan[init_row][1]-self.frameSpan[init_row][0]+1
  44. if self.frame_count>=self.frameSpan[init_row][0] and \
  45. self.frame_count<=self.frameSpan[init_row][1] :
  46. self.image_save(frame,init_row,time_duration)
  47. if self.frame_count==self.frameSpan[init_row][1]:
  48. init_row+=1
  49. if init_row==len(self.frameSpan):
  50. cv.DestroyWindow(win_name)
  51. return 0
  52. c = cv.WaitKey(10)
  53. if c == 27:
  54. break
  55. cv.DestroyWindow(win_name)
  56. def image_save(self,frame,init_row,time_duration):
  57. save_path=self.make_folder(init_row,time_duration)
  58. #frame=Image.fromarray(frame)
  59. #frame.resize((300,300))
  60. #frame.save(‘%s//%s.jpg‘ % (save_path,self.frame_count))
  61. frame=cv2.resize(frame,(300,300))#
  62. cv2.imwrite( ‘%s//%s.jpg‘ % (save_path,self.frame_count), frame)
  63. def make_folder(self,init_row,time_duration):
  64. temp= self.image_prefix+‘_‘+str(init_row)+‘_‘+str(time_duration)#事件名称_事件顺序_
  65. new_path = os.path.join(self.save_path,temp)
  66. if not os.path.isdir(new_path):
  67. os.makedirs(new_path)
  68. return new_path
  69. def read_excel_single(excel_path,event_instance):
  70. data=[]
  71. data=xlrd.open_workbook(excel_path)
  72. #read the first sheets
  73. table = data.sheets()[0]
  74. #read the num fo cols
  75. nrows = table.nrows
  76. rowmsg=[]#用来存储帧的范围,及事件的类别,描述。
  77. for i in xrange(nrows):
  78. start_frame,end_frame=table.row_values(i)[1].split(‘:‘)
  79. rowmsg.append([int(start_frame),int(end_frame),table.row_values(i)[3]])
  80. rowmsg.sort(lambda x,y:cmp(x[0],y[0]))#按照数字大小排序~
  81. event_id=[]
  82. event_id=event_instance
  83. #print event_id
  84. event=[]
  85. for item in xrange(len(rowmsg)):
  86. if rowmsg[item][2]==event_id:#
  87. event.append(rowmsg[item])
  88. if event==[]:
  89. print ("there is no %s occurs" % event_instance)
  90. return 0
  91. #去除重复
  92. cur_pos=1
  93. new_rowmsg=[]
  94. pre_s=event[0][0]
  95. pre_e=event[0][1]
  96. cur_s=event[cur_pos][0]
  97. cur_e=event[cur_pos][1]
  98. while cur_pos<len(event)-1:
  99. while not (cur_s>pre_e):
  100. if cur_s>pre_s:
  101. cur_s=pre_s
  102. if cur_e<pre_e:
  103. cur_e=pre_e
  104. still_pos=[cur_s,cur_e,event_id]
  105. cur_pos+=1
  106. if cur_pos==len(event)-1:
  107. break
  108. pre_s=cur_s
  109. pre_e=cur_e
  110. cur_s=event[cur_pos][0]
  111. cur_e=event[cur_pos][1]
  112. new_rowmsg.append(still_pos)
  113. if cur_pos==len(event)-1:
  114. break
  115. cur_pos+=1
  116. pre_s=cur_s
  117. pre_e=cur_e
  118. cur_s=event[cur_pos][0]
  119. cur_e=event[cur_pos][1]
  120. return new_rowmsg
  121. excel_source=‘E:/08ann/dev_20071101/LGW_20071101_E1_CAM1.mpeg.xlsx‘
  122. event_instance=‘CellToEar‘
  123. row_msg=read_excel_single(excel_source,event_instance)
  124. new_row=[ item[0:2] for item in row_msg ]
  125. filename = "G:/TrecvidData/08/DEV/LGW_20071101_E1_CAM1.mpg"
  126. videoread=videoFramesExtractor(filename,new_row,‘CellToEar‘)
  127. videoread.read()

有几点发现:

cv2.的函数输出的数据类型基本都是numpy,而cv.不行。所以尽量在Python中使用cv2.的函数。

通过numpy转换后的图片会在颜色上有些失真,不过影响不大,如果是灰度图的话则完全没有影响。

时间: 03-21

python 视频处理,提取视频相关帧,读取Excel的相关文章

【爬虫问题】爬取tv.sohu.com的页面, 提取视频相关信息

尝试解决下面的问题 问题: 爬取tv.sohu.com的页面, 提取视频相关信息,不可用爬虫框架完成 何为视频i关信息?属性有哪些? 需求: 做到最大可能的页面覆盖率 *使用httpClient 模拟获取页面HtmlText源码信息,正则出源码视频URL解析类HtmlText2URLlist.ashx. 正则式:href=\"(.*?)\" 选择重要的信息进行存储 选择合适的数据存储方式,便于后续使用 数据库字段 ID.URL.IsSuccess.Title.Isdelete.Vide

根据视频地址获取某一帧的图像

http://blog.fuckbugs.me/category/ios/ //CatchImage.h #import <Foundation/Foundation.h> @interface CatchImage : NSObject /* *videoURL:视频地址(本地/网络) *time      :第N帧 */ + (UIImage*) thumbnailImageForVideo:(NSURL *)videoURL atTime:(NSTimeInterval)time; @e

WebView中的视频全屏的相关操作

最近工作中,基本一直在用WebView,今天就把它整理下: WebView 顾名思义,就是放一个网页,一个看起来十分简单,但是用起来不是那么简单的控件. 首先你肯定要定义,初始化一个webview,其实网上的例子很多,我这里就简单的把一些WebView 中可能会用到的的很重要的属性以及支持全屏播放视频该怎么实现的代码粘出来,直接放到项目中去就行了 <span style="white-space:pre"></span><pre name="co

各种与视频编解码以及视频图像处理的应用相关的新技术,新方法,各种软件开发相关的算法,思想。

1. 各种视频压缩标准(MPEG2, MPEG4, H261/2/3/4,X264, T264以及H264(AVC)和HEVC(H265)等的优化,改进,创新. 2. 各种不同平台的(CPU, GPU, DSP, ARM等等)开发,移植优化等, 涉及到的语言包括C, C++, X86汇编,TI DSP汇编,ADI DSP汇编, ARM汇编(armv4/v5/v6/v7 XSCALE WMMX cortex A8等),MMX, SSE, SSE2/3等, 以及目前利用OpenCL来调用GPU实现并

android平台短视频技术之 视频编辑的经验分享.

提示一: 各位看官,这里分享的是视频编辑,即剪切/拼接/分离/合并/涂鸦/标记/叠加/滤镜等对视频的编辑操作.不是流媒体网络播放等功能,请注意. 提示二: 这些文字90%的为普及知识,10%为宣传我们的SDK,因为分享别人,有利自已,才是良性循环,才可以让我们持续分享,毕竟只分享,不有益很难持续下去.要养家糊口啊^_^. 提示三:我们是android视频编辑的专业团队,以下分享的文字,完全实际经验总结,每一个知识点您都可以在我们的SDK或开源的工程中验证.我们的SDK:https://githu

手动抓取爱奇艺和优酷等视频网站的视频

今天就给大家讲讲怎么手动抓取爱奇艺和优酷等视频网站的视频该方法适用于很多视频网站.因为有的网站不支持我们用一些软件比如硕鼠和维棠等的解析下载,所以我就找到了这个方法,本来优酷之前是可以的,不过现在优酷还是不支持硕鼠和维棠的解析了.这两个网页是原帖的地址,其实我之前知道这个方法,不过这个人提供了一个软件比较好用,我把他录制的视频提取出来了,下面看看吧. 其实原理都是一样,这些视频网站为了让视频更快的缓存,当然也有很多其他原因,把视频分成了很多段,所以我们只需要单独下载好每一段视频,然后把这些视频合

常用视频格式与视频编解码标准介绍 转

细细算起来,视频文件可以分成两大类:其一是影像文件,比如说常见的VCD便是一例.其二是流式视频文件,这是随着国际互联网的发展而诞生的后起视频之秀,比如说在线实况转播,就是构架在流式视频技术之上的.流式视频(Streaming Video)采用一种"边传边播"的方法,即先从服务器上下载一部分视频文件,形成视频流缓冲区后实时播放,同时继续下载,为接下来的播放做好准备.这种"边传边播"的方法避免了用户必须等待整个文件从Internet上全部下载完毕才能观看的缺点. 1.A

目标检测之视频摘要---即视频浓缩,视频检索,视频摘要浓缩

(1)视频摘要应用背景 (2)视频摘要简介 (3)视频浓缩相关技术 (4)视频浓缩残留问题 ---------------author:pkf ----------------------------time:2015-1-26 ------------------------------------qq:1327706646 (1)视频摘要应用背景 说起视频摘要,13年就有看到同事在做这方面的工作,并带个硕士三个月内三个人搞出了个简单demo,当时是给多维视通合作的一个项目,给公安侦查大队使用

C#控制台程序取得INSOYA视频区的视频的真实URL,视频标题,发布时间集合。

准备工作 起因是因为这个网站:http://i.youku.com/kmsfan 这个是一个叫做冒险岛的游戏的资讯论坛,以前我经常在里面传视频,现在我不玩这个游戏了,但是很多玩家还是经常到我的网站里面去看视频,所以我觉得有点不好意思,我觉得开发出一款自动上传下载的工具比什么都好,也不耽误我时间.需要准备一些插件,这些插件都可以从Nuget里面找到,比如Newtonsoft.Json啊HtmlAgilityPack ,不过目前为止也只用到了这些东西.还有我没有做youtube视频的下载,我只做了D

python读取excel文件(xrld模块)

Python读取excel文件 一.python  xlrd模块 安装 mac 下安装python  xlrd模块 http://www.crifan.com/python_read_excel_xls_file_xlrd/comment-page-1/ python setup.py install 在mac 下出现的错误是 http://stackoverflow.com/questions/18199853/error-could-not-create-library-python-2-7