Python快速將ppt制作成配音視頻課件的操作方法
老猿從來沒有錄播個視頻課件,但最近有要求在一周內必須錄制一個視頻課件,為此花了3天時間準備ppt,花了一個小時錄播了一個20多分鐘的課件。
由于第一次干這個活,講課時情緒還是有點緊張,導致錄播的語音出現了各種重復、不該有的間斷、兩頁切換時課件講解過快、部分詞語發音不準等問題,導致效果一團糟。
為了解決這些問題,又使用剪輯軟件進行了剪輯,光剪輯就花了2天時間,結果效果還是不好,最后想到了一個辦法,就是廢掉原錄播材料,將ppt導出成圖像,然后逐頁錄音,再使用合成軟件將圖像和音頻逐一匹配,再進行制作。花了40多分鐘逐頁錄音并試聽,最后花了半天時間制作和輸出,終于趕上最后的截止時間前上交了視頻。如果最開始就用這個方法,可以節省大部分時間。
基于上述過程,老猿又想到最后這個處理過程完全不需要使用合成軟件,而是使用Moviepy是否更好呢?今天付諸行動,發現使用Moviepy進行合成比圖形操作界面的合成軟件效果更好,完美地解決了音頻和ppt材料的協同問題。下面就詳細介紹一下這個過程,供ppt視頻課件制作生手提供一個可以高效制作視頻的方法。
二、ppt視頻課件制作過程 2.1、將ppt保存為一張張圖像打開ppt,選擇:文件 --> 另存為,保存類型選擇為PNG或jpg,如圖:
然后點擊保存,出現:
選擇“每張幻燈片”。這樣就可以將每頁ppt導出成圖片了,如:
相關圖片會輸出到一個單獨的目錄,以“幻燈片XX.png”等形式逐頁輸出保存。
2.2、按頁錄音對照ppt每頁的內容,將該頁講解的語音使用手機錄音軟件等方式錄制成一個個音頻文件,下面是老猿錄制的音頻文件目錄:
注意,在以上錄音時,第18頁和20頁錄制成了2段,這種方式處理和其他頁面不一樣,是不適合用程序來處理的,除非對此針對性的改造。
2.3、編寫代碼進行合成代碼的說明與注釋,不單獨進行補充說明,完整代碼如下:
from moviepy.editor import *import os,tracebackdef isdigit(c): return c>=’0’ and c<=’9’def getPattern(patternString): ''' :param patternString: 含有模式串的字符串,模式串仿C語言整型輸出格式,類似于:%d、%02d等 :return: 返回將patternString拆分成三段的一個列表,三個元素分別是:模式串前面的字符串、模式串(含百分號、數字和d)、模式串后面的字符串,如果沒有找到模式串則返回None ''' patternIndex = patternString.index('%') if patternIndex<0:print('模式字符串中未發現模式匹配符:%')return None matched = False for patternEnd in range(patternIndex+1,len(patternString)):if patternString[patternEnd]in’dD’: matched = True breakelse: if not isdigit(patternString[patternEnd]):print('模式字符串中的模式存在非數字')return None if matched: return [patternString[:patternIndex],patternString[patternIndex:patternEnd+1],patternString[patternEnd+1:]] else:print('模式字符串中的模式不是字母d結尾')return Nonedef composePPTImgsAndSounds(imgFilePattern,soundFilePattern,startSeq=1,endSeq=None): ''' :param imgFilePattern: 圖像文件模式,要求圖像文件中必須含文件序號,序號采用%d、%02d/%03d的方式來識別 :param soundFilePattern:音頻文件格式,要求文件中必須含文件序號,序號采用%d、%02d/%03d的方式來識別 :param startSeq:文件序列號其實值,一般為0或1 :param endSeq:文件序列號結束值,可以不填 :return:生成的視頻 ''' if endSeq is None:endSeq=9999999 #當對應序號找不到文件時結束 patterns = getPattern(imgFilePattern) if patterns is None:print(’圖像文件名不符合模式格式要求’)return None else:imgPrefix,imgPattern,imgPostfix = patterns patterns = getPattern(soundFilePattern) if patterns is None:print(’音頻文件名不符合模式格式要求’)return None else:soundPrefix, soundPattern, soundPostfix = patterns clips = [] try:for seq in range(startSeq,endSeq): imgFName = f'{imgPrefix}{seq:{imgPattern[1:]}}{imgPostfix}' soundFName = f'{soundPrefix}{seq:{soundPattern[1:]}}{soundPostfix}' if os.path.exists(soundFName) and os.path.exists(imgFName):soundClip = AudioFileClip(soundFName)imgClip = ImageClip(imgFName).set_duration(soundClip.duration).set_fps(2).set_audio(soundClip)clips.append(imgClip) else:if seq: print(f'音視和圖像文件加載結束,最后一個文件的序號為{seq}') breakelse: print(f'圖像文件{imgClip}或音頻文件{soundClip}不存在') return None except Exception as e:print(f'加載音頻和圖像文件失敗:n{e}n{traceback.format_exc()}')return None print('輸出視頻文件....') clip = concatenate_videoclips(clips,’compose’) clip.write_videofile(r'C:tempppt.mp4',threads=8) print('視頻文件已經生成') return clipcomposePPTImgsAndSounds(r’F:bakpr大H十百千視頻制作5G在線計費動態授權機制介紹3.9幻燈片%d.PNG’,r’C:temp錄音文件p%d.m4a’)
如果不了解Moviepy的,請參考《 Python音視頻剪輯庫MoviePy1.0.3中文教程導覽及可執行工具下載》的導覽式介紹。
三、效果使用該方式制作的視頻,比圖形界面合成軟件制作的視頻效果更流暢、大小更小、制作時間也更短,大小大概是圖形界面視頻合成軟件的不到十分之一,視頻輸出時間是圖形界面合成軟件手工輸出的四分之一,還省了手工去進行合成剪輯的過程(非熟練人員一般需要1-2個小時),老猿20分鐘的視頻課,含錄音、試聽及部分重錄時間,整個制作過程不到70分鐘(不含代碼編寫時間),是不是特別好用?
不過注意,老猿上面的案例處理到第18頁時就認為課件完結了,要將整個課件處理完,需要合并18頁和20頁的音頻輸出到其他音頻文件類似的音頻文件中。
四、小結本文介紹了一種ppt視頻課件快速制作的方法,通過將ppt輸出成一張張圖片,然后逐頁配音,最后使用Moviepy將其合成輸出,課件制作又快又好。由于采用了分頁錄音的方式,對于講解不好的地方很快就可以更換,因此比期望一次性錄播然后剪輯的效果要好很多,同時輸出的視頻文件小、輸出快。
以上就是Python快速將ppt制作成配音視頻課件的操作方法的詳細內容,更多關于python ppt配音視頻課件的資料請關注好吧啦網其它相關文章!
相關文章:
1. .NET SkiaSharp 生成二維碼驗證碼及指定區域截取方法實現2. ASP.NET MVC通過勾選checkbox更改select的內容3. Django使用HTTP協議向服務器傳參方式小結4. HTTP協議常用的請求頭和響應頭響應詳解說明(學習)5. CentOS郵件服務器搭建系列—— POP / IMAP 服務器的構建( Dovecot )6. IntelliJ IDEA創建web項目的方法7. ASP中實現字符部位類似.NET里String對象的PadLeft和PadRight函數8. .NET 6實現滑動驗證碼的示例詳解9. 存儲于xml中需要的HTML轉義代碼10. 原生JS實現記憶翻牌游戲
