用python進行視頻剪輯
用進行視頻剪輯
更新時間:2020年11月02日 16:03:03 作者:
這篇文章主要介紹了如何用進行視頻剪輯,幫助大家更好的利用處理視頻,感興趣的朋友可以了解下
一、目標
,利用和將一段視頻進行區間切割
二、源碼
import os from moviepy.video.io.VideoFileClip import VideoFileClip from pydub import AudioSegment def clip_video(source_file, target_file, start_time, stop_time): """ 利用moviepy進行視頻剪切 :param source_file: 原視頻的路徑,mp4格式 :param target_file: 生成的目標視頻路徑,mp4格式 :param start_time: 剪切的起始時間點(第start_time秒) :param stop_time: 剪切的結束時間點(第stop_time秒) :return: """ validate_file(source_file) source_video = VideoFileClip(source_file) video = source_video.subclip(int(start_time), int(stop_time)) # 執行剪切操作 video.write_videofile(target_file) # 輸出文件 def clip_audio(source_file, target_file, start_time, stop_time): """ 利用pydub進行音頻剪切。pydub支持源文件為 mp4格式,因此這里的輸入可以與視頻剪切源文件一致 :param source_file: 原視頻的路徑,mp4格式 :param target_file: 生成的目標視頻路徑,mp4格式 :param start_time: 剪切的起始時間點(第start_time秒) :param stop_time: 剪切的結束時間點(第stop_time秒) :return: """ validate_file(source_file) audio = AudioSegment.from_file(source_file, "mp4") audio = audio[start_time * 1000: stop_time * 1000] audio_format = target_file[target_file.rindex(".") + 1:] audio.export(target_file, format=audio_format) def combine_video_audio(video_file, audio_file, target_file, delete_tmp=False): """ 利用 ffmpeg將視頻和音頻進行合成 :param video_file: :param audio_file: :param target_file: :param delete_tmp: 是否刪除剪切過程生成的原視頻/音頻文件 :return: """ validate_file(video_file) validate_file(audio_file) # 注:需要先指定音頻再指定視頻,否則可能出現無聲音的情況 command = "ffmpeg -y -i {0} -i {1} -vcodec copy -acodec copy {2}".format(audio_file, video_file, target_file) os.system(command) if delete_tmp: os.remove(video_file) os.remove(audio_file) def clip_handle(source_file, target_file, start_time, stop_time, tmp_path=None, delete_tmp=False): """ 將一個視頻文件按指定時間區間進行剪切 :param source_file: 原視頻文件 :param target_file: 目標視頻文件 :param start_time: 剪切的起始時間點(第start_time秒) :param stop_time: 剪切的結束時間點(第stop_time秒) :param tmp_path: 剪切過程的文件存放位置 :param delete_tmp: 是否刪除剪切生成的文件 :return: """ # 設置臨時文件名 if tmp_path is None or not os.path.exists(tmp_path): # 如果沒有指定臨時文件路徑,則默認與目標文件的位置相同 tmp_path = target_file[: target_file.rindex("/") + 1] target_file_name = target_file[target_file.rindex("/") + 1: target_file.rindex(".")] tmp_video = tmp_path + "v_" + target_file_name + ".mp4" tmp_audio = tmp_path + "a_" + target_file_name + ".mp4" # 執行文件剪切及合成 clip_video(source_file, tmp_video, start_time, stop_time) clip_audio(source_file, tmp_audio, start_time, stop_time) combine_video_audio(tmp_video, tmp_audio, target_file, delete_tmp) def validate_file(source_file): if not os.path.exists(source_file): raise FileNotFoundError("沒有找到該文件:" + source_file) def test_example(): """ 測試例子 :return: """ root_path = 'XXX/videos/' video_name = "test.mp4" source_file = root_path + video_name start_time = 5 stop_time = 6 # 設置目標文件名 target_name = str(start_time) + "_" + str(stop_time) target_file = root_path + "c_" + target_name + ".mp4" # 處理主函數 clip_handle(source_file, target_file, start_time, stop_time) if __name__ == "__main__": test_example()
三、遇到的問題
1. 切割后的視頻沒有聲音
解決方案:通過切割后再合并
2. 直接利用切割后,視頻會出現黑屏、時間區間不準確、分辨率低
解決方案:用了各種命令也沒有成功,所以放棄。。。
3. 合并時,不支持mp3、 wav等格式
解決方案:統一保存為mp4
聲明:本站所有文章資源內容,如無特殊說明或標注,均為采集網絡資源。如若本站內容侵犯了原著者的合法權益,可聯系本站刪除。