如何使用Python来提取视频中的音频
Posted digolds
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使用Python来提取视频中的音频相关的知识,希望对你有一定的参考价值。
如何使用Python来提取视频中的音频
在这篇文章中,我将解释如何使用Python来提取视频中的音频。提取结束之后,你将得到视频中的音频文件,之后,你便可以把音频文件用在其它项目中。整个过程可以拆分成以下几步:
- 安装ffmpeg和MoviePy
- 读取视频文件
- 输出音频文件
- 一个完整的例子
安装ffmpeg和MoviePy
为了操作视频文件,我们需要执行以下命令来安装Python的两个第三方库:ffmpeg和MoviePy,后者依赖前者。
pip install ffmpeg moviepy
读取视频文件
接下来,创建文件extract_audio.py
,把以下内容复制到文件里
import moviepy.editor as mp
def extract_audio(videos_file_path):
my_clip = mp.VideoFileClip(videos_file_path)
以上代码做的事情是把视频文件读取到my_clip
中,其中视频的路径可以通过videos_file_path
来指定。比如,我的电脑里有一个视频文件,它的路径名是C:\\my_videos\\abc.mp4,那么你可以通过以下方式来读取该视频文件:
extract_audio('C:\\my_videos\\abc.mp4')
当我们读取视频文件之后,接下来的步骤就是要提取该视频里的音频内容,并存成mp3文件。
输出音频文件
我们只需要在extract_audio.py中添加以下指令,就能将视频中的声音提取出来:
my_clip.audio.write_audiofile(f'videos_file_path.mp3')
以上指令的作用是把视频中的声音提取出来,并将声音存储成mp3文件。
extract_audio.py中的最终内容,如下所示:
import moviepy.editor as mp
def extract_audio(videos_file_path):
my_clip = mp.VideoFileClip(videos_file_path)
my_clip.audio.write_audiofile(f'videos_file_path.mp3')
一个完整的例子
假设,你的电脑里有一个视频文件:C:\\video\\abc.mp4,那么你可以在extract_audio.py中添加以下指令来输出视频里的音频内容。
extract_audio(r'C:\\video\\abc.mp4')
_extract_audio.py_中的最终内容,如下所示:
import moviepy.editor as mp
def extract_audio(videos_file_path):
my_clip = mp.VideoFileClip(videos_file_path)
my_clip.audio.write_audiofile(f'videos_file_path.mp3')
extract_audio(r'C:\\video\\abc.mp4')
接下来,打开命令行,并执行文件extract_audio.py,如果执行成功,那么你将在目录C:\\video中看到以下文件:
abc.mp4.mp3
参考
Python 批量提取视频中的音频
Python 批量提取视频中的音频:
1. python 提取视频中的音频
将视频中的音频分离出来,另存为MP3
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
# 获取文件名称
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 == 'video/mp4':
extractMp3(path)
else:
print(f"跳过文件path")
return
# 递归遍历
for dir in os.listdir(path):
# 音频保存的路径目录不存在新建
voice_path = path.replace(root, rootVoice)
os.makedirs(voice_path) if not os.path.exists(
voice_path) else 1
getVideoList(os.path.join(path, dir))
root = "C:\\\\Users\\\\26590\\\\Videos\\\\智慧城市\\\\"
rootVoice = "C:\\\\Users\\\\26590\\\\Videos\\\\智慧城市voice\\\\"
voiceType = "mp3"
getVideoList(root)
以上是关于如何使用Python来提取视频中的音频的主要内容,如果未能解决你的问题,请参考以下文章