使用Python实现音频双通道分离

2020-12-26 17:11:32 IT技术网 互联网
浏览

某些音频是双方对话,有可能需要对音频作通道的分离。

示例代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
音频双通道分离
"""
import sys
import numpy as np
from scipy.io import wavfile
from converter import mp3_to_wav


def split_channel(wav_path, left_wav_path, right_wav_path):
 """
 通道分离
 :param wav_path: wav音频的路径
 :param left_wav_path: 左声道的wav音频路径
 :param right_wav_path: 右声道的wav音频路径
 :return None:
 """
 try:
  sample_rate, wav_data = wavfile.read(wav_path)
  left = []
  right = []
  for item in wav_data:
   left.append(item[0])
   right.append(item[1])
  wavfile.write(left_wav_path, sample_rate, np.array(left))
  wavfile.write(right_wav_path, sample_rate, np.array(right))
 except IOError as e:
  print('error is %s' % str(e))
 except:
  print('other error', sys.exc_info())


if __name__ == '__main__':
 mp3_to_wav('input/test.mp3', 'tmp/tmp.wav')
 split_channel('tmp/tmp.wav', 'output/left.wav', 'output/right.wav')

其中调用了一个自定义的库,converter.py 加入了代码:

from pydub import AudioSegment


def mp3_to_wav(source, destin):
 """
 mp3 转 wav
 :param source:
 :param destin:
 :return None:
 """
 data = AudioSegment.from_mp3(source)
 data.export(destin, format='wav')

本代码示例可以生成两个通道分离后的 wav 文件。

注意:如果源文件的格式是 wav 文件,可以省掉转换格式的过程。

以上就是使用Python实现音频双通道分离的详细内容,更多关于python 音频分离的资料请关注IT技术网其它相关文章!

您可能感兴趣的文章:

  • Python做图像处理及视频音频文件分离和合成功能
  • python音频处理的示例详解
  • Python爬虫实战案例之爬取喜马拉雅音频数据详解
  • ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
  • python将音频进行变速的操作方法
  • Python 读取WAV音频文件 画频谱的实例
  • Python3.7 读取 mp3 音频文件生成波形图效果
  • 利用Python小工具实现3秒钟将视频转换为音频
  • python脚本实现音频m4a格式转成MP3格式的实例代码
  • 详解python播放音频的三种方法