使用python-cv2實現(xiàn)視頻的分解與合成的示例代碼
1.視頻分解圖片
我們使用cv2.VideoCapture來讀取視頻
import cv2cap = cv2.VideoCapture(’1.mp4’)isOpened = cap.isOpened # 判斷視頻是否可讀print(isOpened)fps = cap.get(cv2.CAP_PROP_FPS) # 獲取圖像的幀,即該視頻每秒有多少張圖片width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)) # 獲取圖像的寬度和高度height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))print(fps, width, height)i = 0while(isOpened): if i == 10: break # 讀取每一幀,falg表示是否讀取成功,frame為圖片的內(nèi)容 (flag, frame) = cap.read() filename = ’img’ + str(i) + ’.jpg’ # 文件的名字 if flag: cv2.imwrite(filename, frame, [cv2.IMWRITE_JPEG_QUALITY,100]) # 保存圖片 i += 1
2.圖片合成視頻
我們使用cv2.VideoWrite方法來創(chuàng)建一個video寫入器
用cv2.VideoWriter_fourcc創(chuàng)建視頻編解碼器
要創(chuàng)建mp4類型的視頻文件,視頻編解碼器為cv2.VideoWriter_fourcc(’M’, ’J’, ’P’, ’G’)
import cv2img = cv2.imread(’img0.jpg’)width = img.shape[0]height = img.shape[1]size = (height, width)print(size)videoname = '2.mp4' # 要創(chuàng)建的視頻文件名稱 fourcc = cv2.VideoWriter_fourcc(’M’, ’J’, ’P’, ’G’) # 編碼器 fps = 5 # 幀率# 1.要創(chuàng)建的視頻文件名稱 2.編碼器 3.幀率 4.sizevideoWrite = cv2.VideoWriter(videoname,fourcc, fps, size)for i in range(10): filename = ’img’ + str(i) + ’.jpg’ img = cv2.imread(filename) videoWrite.write(img) # 寫入
720 1280
到此這篇關(guān)于使用python-cv2實現(xiàn)視頻的分解與合成的文章就介紹到這了,更多相關(guān)使用python-cv2實現(xiàn)視頻的分解與合成內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Java如何基于反射機制獲取不同的類2. Android table布局開發(fā)實現(xiàn)簡單計算器3. jQuery 實現(xiàn)DOM元素拖拽交換位置的實例代碼4. IntelliJ IDEA安裝插件的方法步驟5. php模擬實現(xiàn)斗地主發(fā)牌6. 理解PHP5中static和const關(guān)鍵字7. Vue封裝一個TodoList的案例與瀏覽器本地緩存的應用實現(xiàn)8. python 代碼實現(xiàn)k-means聚類分析的思路(不使用現(xiàn)成聚類庫)9. .Net Core使用Coravel實現(xiàn)任務調(diào)度的完整步驟10. PHP安全-命令注入

網(wǎng)公網(wǎng)安備