使用python实现将视频中的音频分离出来
作者:Mabel-mql
这篇文章主要介绍了使用python实现将视频中的音频分离出来,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
将视频中的音频分离出来
简单介绍
使用python将音频从视频当中分离出来,形成一个mp3格式的音乐。
使用环境和模块
1.python 3.7
2.moviepy----用于视频编辑的Python模块,可用于基本操作(如剪切、连接、标题插入以及视频合成、视频处理或创建高级效果。它可以读写最常见的视频格式,包括GIF。
可直接使用如下命令进行安装:
pip install moviepy -i https://pypi.douban.com/simple
相关代码
‘'' ##从视频中获取音频 from moviepy.editor import VideoFileClip,AudioFileClip,afx video = VideoFileClip(“Why Don't We-What Am I.mp4”) audio = video.audio audio.write_audiofile(‘what am I.mp3') ‘''
运行上述代码后,自动生成一个mp3格式音频
效果图如下
批量提取视频中的音频
1. python 提取视频中的音频
将视频中的音频分离出来,另存为MP3
方法1:FFmpeg
方法2:moviepy
2. 批量提取【目录】
提取单个文件、提取目录下所有视频的音频
1. python 提取视频中的音频
1.1 方法1:
使用 FFmpeg 方法提取音频
提取代码如下:
import os from ffmpy import FFmpeg # 获取文件名称 def getName(video_path): return os.path.basename(video_path).split('.')[0] # 提取并另存为 def run_ffmpeg(video_path: str, audio_path: str, format: str): ff = FFmpeg(inputs={video_path: None}, outputs={audio_path: '-f {} -vn'.format(format)}) ff.run() return audio_path # 参数接受处理 def extract(video_path: str, tmp_dir: str, ext: str): file_name = '.'.join(os.path.basename(video_path).split('.')[0:-1]) return run_ffmpeg(video_path, os.path.join(tmp_dir, '{}.{}'.format(getName(video_path), ext)), ext) if __name__ == '__main__': root = "D:\\study\\project\\python\\技巧\\提取视频音频\\" print(extract(root + '我是不是该安静的走开.mp4', root, 'mp3'))
1.2 方法2:
moviepy
from moviepy.editor import * root = "D:\\study\\project\\python\\技巧\\提取视频音频\\" audio = VideoFileClip(root + "我是不是该安静的走开.mp4").audio audio.write_audiofile(root + "我是不是该安静的走开.mp3")
2. 批量提取【目录】
提取目录下所有视频中的音频,将所有音频保存在新的目录中,文件相对目录对应
from moviepy.editor import * import os import filetype import argparse # 修改这里啊 root = "C:\\Users\\26590\\Videos\\智慧城市\\" rootVoice = "C:\\Users\\26590\\Videos\\智慧城市voice\\" voiceType = "mp3" videoType = "video/mp4" # 获取文件名称 def getName(video_name): return os.path.basename(video_name).split('.')[0] # 修改文件后缀例如: C:/dir/a/b.png 需要转为 C:/dir/a/b.jpg 调用函数:trAffter('C:/dir/a/b.png', 'jpg') def trAffter(path, type): a = path.split('/') b = a[-1].split('.') b[-1] = voiceType a[-1] = '.'.join(b) return '/'.join(a) # 提取音频 def extractMp3(video_path): print("提取文件:", video_path) audio = VideoFileClip(video_path).audio # 音频保存的路径 voice_path = video_path.replace(root, rootVoice) print("\t音频保存至:", trAffter(voice_path, voiceType)) audio.write_audiofile(trAffter(voice_path, voiceType)) # 遍历目录下的所有文件 def getVideoList(path): # 是否为文件 if not os.path.isdir(path): ft = filetype.guess(path) if ft is not None and ft.mime == videoType: extractMp3(path) else: print(f"跳过文件{path}") return # 递归遍历 for dir in os.listdir(path): # 音频保存的路径目录不存在新建 voice_path = path.replace(root, rootVoice) if not os.path.exists(voice_path): os.makedirs(voice_path) getVideoList(os.path.join(path, dir)) # 开始 getVideoList(root)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。