利用Python將多張圖片合成視頻的實現
今天要做一個量子隧穿的的演示動畫,在CSDN上看了很多大佬的文章,然而忙了接近半天才做好這件事。把踩過的坑記一下,同時這段代碼也是值得記錄的,因為以后也可能遇到類似的工作。
先上代碼`
import numpy as npimport cv2#讀取一張圖片size = (432,288)print(size)#完成寫入對象的創建,第一個參數是合成之后的視頻的名稱,第二個參數是可以使用的編碼器,第三個參數是幀率即每秒鐘展示多少張圖片,第四個參數是圖片大小信息videowrite = cv2.VideoWriter(r’F:test.mp4’,-1,20,size)#20是幀數,size是圖片尺寸img_array=[]for filename in [r’F:Picture{0}.png’.format(i) for i in range(600)]: img = cv2.imread(filename) if img is None: print(filename + ' is error!') continue img_array.append(img)for i in range(600): videowrite.write(img_array[i])print(’end!’)
算法的核心思想,大家的代碼可能千差萬別,但是思路都是一樣的。
1.利用cv2.imread()讀取圖片文件2.利用cv2.VideoWriter()產生一個對象3.調用這個對象的write方法將所需的圖片寫進去,這樣就生成了一個視頻
幾個大坑:
1.
size = (432,288)#這邊是圖片的尺寸,圖片的尺寸得是一樣的,不一樣的話有個博主編了一個resize函數可以去參考一下
2.imread函數無法讀取有中文字符的路徑,一定得是英文字符
3.videowrite = cv2.VideoWriter(r’F:test.mp4’,-1,20,size)這邊的路徑好像也得是英文,我試了含有中文的路徑不行
我把圖片命名為0~599.png
按照以上的代碼文件生成了一下的視頻文件
到此這篇關于利用Python將多張圖片合成視頻的實現的文章就介紹到這了,更多相關Python 圖片合成視頻內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: