使用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)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程宝库

自动追踪算法,在我们制作射击类游戏时经常会用到。这个听起来很高大上的东西,其实并不是军事学的专利,从数学上来说就是解微分方程。这个没有点数学基础是很难算出来的。但是我们有了计算机就不一样了,依靠计算机极 ...