python+opencv實現視頻抽幀示例代碼
雖然有主流龐大的COCO、VOC數據集,但是科研人員仍需要特殊領域要求的數據集,所以采用人工實地采集的方式進行收集數據集圖像;通過拍照收集圖像過于繁瑣,所以通常是將攝像頭無規則的移動旋轉以及遠近拉縮,進而錄制視頻;再通過視頻抽幀的方式得到大量的圖像,再將這些圖像進行人工標注處理。
博主通過一個水下錄制視頻為例子,當這類圖像在網上鮮有存在時,要求有關技術人員進行實拍采集,下圖即為采集得到的視頻。
為了避免不符合項目要求的數據增強,博主要求技術人員在錄制視頻時最大程度地讓攝像頭進行移動、旋轉以及遠近調節等;這樣抽幀后的圖像更具有泛化性。
2、代碼介紹:下面是采用以幀數為間隔的方法進行視頻抽幀,博主個人認為這樣子的方式調節間隔更加方便,更符合個人習慣。
import cv2from PIL import Imageimport numpy as npcap = cv2.VideoCapture('D:/Download/ANMR0005.mp4') # 獲取視頻對象isOpened = cap.isOpened # 判斷是否打開# 視頻信息獲取fps = cap.get(cv2.CAP_PROP_FPS)imageNum = 0sum=0timef=15 #隔15幀保存一張圖片while (isOpened): sum+=1 (frameState, frame) = cap.read() # 記錄每幀及獲取狀態 if frameState == True and (sum % timef==0):# 格式轉變,BGRtoRGBframe = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)# 轉變成Imageframe = Image.fromarray(np.uint8(frame))frame = np.array(frame)# RGBtoBGR滿足opencv顯示格式frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR)imageNum = imageNum + 1fileName = ’D:/Download/video_image/image’ + str(imageNum) + ’.jpg’ # 存儲路徑cv2.imwrite(fileName, frame, [cv2.IMWRITE_JPEG_QUALITY, 100])print(fileName + ' successfully write in') # 輸出存儲狀態 elif frameState == False:breakprint(’finish!’)cap.release()3、代碼效果:
pycharm運行py文件后結果框顯示的內容:
視頻抽幀得到的圖像保存至指定的文件夾:
抽幀得到的圖片示例:
4、相關說明: ①本代碼依據錄制視頻、對opencv的理解以及大佬的項目代碼靈感進行編寫;
大佬的項目代碼地址
②本數據集屬于私人閉源,不公開。
到此這篇關于python+opencv實現視頻抽幀的文章就介紹到這了,更多相關python opencv視頻抽幀內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: