doc2video / audio2video.py
zhao1977's picture
Upload 15 files
dd74184 verified
import os
from moviepy.editor import *
from glob import glob
import re
def merge_audio_and_add_to_video(video_path, audio_base_dir, output_path):
"""
合并多个音频文件并添加到视频中。
:param video_path: 视频文件的路径。
:param audio_base_dir: 包含音频文件夹的基目录。
:param output_path: 输出视频的路径。
"""
# 加载视频文件
video_clip = VideoFileClip(video_path)
# 初始化音频列表
audio_clips = []
silent_audio_start = AudioClip(lambda t: [0,0], duration=2)
audio_clips.append(silent_audio_start)
# 遍历所有子目录,按数字大小排序
audio_dirs = glob(os.path.join(audio_base_dir, "audio_for_paragraph_*"))
audio_dirs.sort(key=lambda x: int(re.search(r'\d+', os.path.basename(x)).group()))
# 遍历所有子目录
for audio_dir in audio_dirs:
# 获取当前目录的index
index = int(os.path.basename(audio_dir).split("_")[-1])
# 遍历目录中的所有mp3文件
mp3_files = glob(os.path.join(audio_dir, f"paragraph_{index}_sentence_*.mp3"))
mp3_files.sort(key=lambda x: int(re.search(r'_sentence_(\d+)', os.path.basename(x)).group(1)))
# 遍历排序后的mp3文件列表
for mp3_file in mp3_files:
# 加载音频文件
audio_clip = AudioFileClip(mp3_file)
# 添加到音频列表
if audio_clips:
# 如果不是第一个音频,则在前一个音频之后添加0.5秒的静音
# 替换原有的 AudioNullClip 代码
silent_audio = AudioClip(lambda t: [0,0], duration=0.3)
audio_clips.append(silent_audio)
audio_clips.append(audio_clip)
# 合并所有音频片段
final_audio = concatenate_audioclips(audio_clips)
# 将音频添加到视频中
video_with_audio = video_clip.set_audio(final_audio)
# 输出带有新音频的视频文件
video_with_audio.write_videofile(output_path, codec='libx264', audio_codec='aac')
# 关闭剪辑对象,释放资源
video_clip.close()