背景
我们想要单独获取视频的音频和无声的视频,我们可以通过ffmpeg来实现。
命令行
# 提取音频
ffmpeg -i input.mp4 -vn -c:a libmp3lame output.mp3
# 提取无声视频
ffmpeg -i input.mp4 -c:v copy -an output.mp4
-i input.mp4:指定输入文件,input.mp4 是你的视频文件。
-an:-an 是 -audio 的简写,后面不跟参数表示禁用音频。
output.mp4:指定输出文件,这里是 output.mp4,将会是一个没有音频的视频文件。
-vn:表示禁用视频,只提取音频。
-c:a libmp3lame:指定音频编解码器为 libmp3lame,这是 FFmpeg 中用于编码 MP3 文件的编解码器。
output.mp3:指定输出文件名,这里 output.mp3 将会是提取出的音频文件。
批量处理
import os
import subprocess
# 设置视频文件夹路径
video_folder = r'E:\Users\Videos\result'
# 设置输出文件夹路径
output_folder = r'E:\Users\Videos\result\re'
# 确保输出文件夹存在
if not os.path.exists(output_folder):
os.makedirs(output_folder)
# 遍历文件夹中的所有文件
for filename in os.listdir(video_folder):
# 检查文件扩展名是否为视频文件
if filename.endswith('.mp4'):
# 构建完整的文件路径
video_path = os.path.join(video_folder, filename)
# 构建输出音频文件和无声视频文件的路径
audio_path = os.path.join(output_folder, filename.replace('.mp4', '.mp3'))
silent_video_path = os.path.join(output_folder, filename.replace('.mp4', '_silent.mp4'))
# 提取音频
subprocess.run(['ffmpeg', '-i', video_path, '-vn', '-c:a', 'libmp3lame', audio_path])
# 提取无声视频
subprocess.run(['ffmpeg', '-i', video_path, '-c:v', 'copy', '-an', silent_video_path])
print("处理完成。")