python實(shí)現(xiàn)批量視頻分幀、保存視頻幀
本篇博客介紹利用python腳本實(shí)現(xiàn)視頻分幀,并將每一幀保存到本地。主要基于opencv包來實(shí)現(xiàn),在運(yùn)行代碼前確保opencv包已正確安裝。下面是主要代碼:
import os import cv2 videos_src_path = '/home/shao/violence_detection_code/Movies_Dataset/fights' videos_save_path = '/home/shao/violence_detection_code/Movies_Dataset/fights_pic' videos = os.listdir(videos_src_path) videos.sort(key=lambda x:int(x[5:-4])) i = 1 for each_video in videos: if not os.path.exists(videos_save_path + '/' + str(i)): os.mkdir(videos_save_path + '/' + str(i)) each_video_save_full_path = os.path.join(videos_save_path,str(i))+'/' each_video_full_path = os.path.join(videos_src_path,each_video) cap = cv2.VideoCapture(each_video_full_path) frame_count = 1 success = True while(success): success,frame = cap.read() if success==True: cv2.imwrite(each_video_save_full_path + "frame%d.jpg" % frame_count, frame) frame_count = frame_count + 1 i = i + 1 cap.release()
代碼注釋:
1.第1,2行完成導(dǎo)入幾個(gè)需要的包;
2.第4,5行分別是待分幀的原始視頻路徑、分幀后需要保存視頻幀的文件路徑;這里需要注意的是,我寫的是文件夾,也就是說在/home/shao/violence_detection_code/Movies_Dataset/fights目錄下有多個(gè)視頻XXX.avi,XXX.avi等形式;如果只需要處理單個(gè)視頻的話,可以稍微改一下即可。
3.第7行表示將所有視頻的文件名存到videos中,第8行是可選項(xiàng),表示對(duì)fights文件夾下的視頻進(jìn)行排序,x[5:-4]表示按照文件名第5個(gè)字符到倒數(shù)第4個(gè)字符之間的符號(hào)排序,因?yàn)槲业囊曨l是newfi1.avi,newfi2.avi……的格式,我想實(shí)現(xiàn)的是按照數(shù)字1,2,3的順序提取視頻幀;
4.之后的代碼就是循環(huán)處理每個(gè)視頻,將每個(gè)視頻的視頻幀保存到文件夾中。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python讀取視頻流提取視頻幀的兩種方法
- python使用opencv按一定間隔截取視頻幀
- python 讀取視頻,處理后,實(shí)時(shí)計(jì)算幀數(shù)fps的方法
- python tools實(shí)現(xiàn)視頻的每一幀提取并保存
- python通過ffmgep從視頻中抽幀的方法
- Python OpenCV對(duì)本地視頻文件進(jìn)行分幀保存的實(shí)例
- Python將視頻或者動(dòng)態(tài)圖gif逐幀保存為圖片的方法
- 使用Python實(shí)現(xiàn)跳幀截取視頻幀
- 使用python-opencv讀取視頻,計(jì)算視頻總幀數(shù)及FPS的實(shí)現(xiàn)
- python+opencv實(shí)現(xiàn)移動(dòng)偵測(cè)(幀差法)
相關(guān)文章
利用selenium爬蟲抓取數(shù)據(jù)的基礎(chǔ)教程
這篇文章主要給大家介紹了關(guān)于如何利用selenium爬蟲抓取數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用selenium具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
Scrapy基于scrapy_redis實(shí)現(xiàn)分布式爬蟲部署的示例
這篇文章主要介紹了Scrapy基于scrapy_redis實(shí)現(xiàn)分布式爬蟲部署的示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Python?第三方庫(kù)?openpyxl?的安裝過程
這篇文章主要介紹了Python?高效辦公第三方庫(kù)?openpyxl?的安裝,本文介紹了什么是庫(kù)及庫(kù)的分類,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
解決python3中的requests解析中文頁(yè)面出現(xiàn)亂碼問題
requests是一個(gè)很實(shí)用的Python HTTP客戶端庫(kù),編寫爬蟲和測(cè)試服務(wù)器響應(yīng)數(shù)據(jù)時(shí)經(jīng)常會(huì)用到。這篇文章給大家介紹了解決python3中的requests解析中文頁(yè)面出現(xiàn)亂碼問題,感興趣的朋友一起看看吧2019-04-04
Pycharm遠(yuǎn)程連接服務(wù)器并運(yùn)行與調(diào)試
本篇文章介紹一下 Pycharm 如何配置遠(yuǎn)程連接信息,使其能夠在本地使用服務(wù)器上的GPU等硬件資源,并在本地完成代碼的運(yùn)行與調(diào)試,感興趣的可以了解一下2021-08-08
Python利用openpyxl庫(kù)遍歷Sheet的實(shí)例
今天小編就為大家?guī)硪黄狿ython利用openpyxl庫(kù)遍歷Sheet的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05
利用機(jī)器學(xué)習(xí)預(yù)測(cè)房?jī)r(jià)
這篇文章主要介紹了利用機(jī)器學(xué)習(xí)回歸模型預(yù)測(cè)房?jī)r(jià),解釋清晰,代碼詳細(xì),是很不錯(cuò)的機(jī)器學(xué)習(xí)實(shí)戰(zhàn)演練,對(duì)機(jī)器學(xué)習(xí)感興趣的朋友可以參考一下2021-04-04
python調(diào)用stitcher類自動(dòng)實(shí)現(xiàn)多個(gè)圖像拼接融合功能
這篇文章主要介紹了python調(diào)用stitcher類自動(dòng)實(shí)現(xiàn)多個(gè)圖像拼接融合功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
Python實(shí)現(xiàn)將長(zhǎng)圖制作成一個(gè)視頻
這篇文章主要為大家詳細(xì)介紹了Python如何實(shí)現(xiàn)將一個(gè)長(zhǎng)圖制作成一個(gè)視頻,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-05-05

