1. 程式人生 > 程式設計 >使用Python實現音訊雙通道分離

使用Python實現音訊雙通道分離

某些音訊是雙方對話,有可能需要對音訊作通道的分離。

示例程式碼如下:

#!/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,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 音訊分離的資料請關注我們其它相關文章!