在python中修剪音频

时间:2013-10-15 05:15:05

标签: python audio wav pyaudio

好吧所以我也使用pyaudio但是从我看过的wave模块可能可以帮助我在这里。

所以我试图在我的程序中添加一个修剪功能,我的意思是我试图让用户找到一部分wav。他/她不喜欢并且有能力修剪波形文件但是他/她想要它。

到目前为止,我一直在使用pyaudio进行简单的播放,而对于从输入设备进行录制,pyaudio非常简单。

我一直在搜索pyaudio我可以做什么来修剪音频,但我真的找不到任何可以帮助我的东西。虽然在嵌入式波模块上我看到有设置位置的方法。

我是否必须完成一个循环或if声明,以便程序知道要记录哪些位置,然后使用pyaudio或wave模块来记录用户设置位置(开头,结尾)的歌曲?如果我以这种方式接近它,我的程序会有效运行吗?

1 个答案:

答案 0 :(得分:3)

我们假设您使用scipy读取wave文件。

然后你需要有“编辑点”这些是用户想要保留的输入和输出值(以秒为单位)。您可以从文件中获取这些内容,也可以显示wave文件并从鼠标中获取点击。如果用户提供应该删除的音频文件的部分,则需要首先否定

这不是最有效的解决方案,但对于许多情况应该没问题。

import scipy.io.wavfile
fs1, y1 = scipy.io.wavfile.read(filename)
l1 = numpy.array([  [7.2,19.8], [35.3,67.23], [103,110 ] ])
l1 = ceil(l1*fs1)#get integer indices into the wav file - careful of end of array reading with a check for greater than y1.shape
newWavFileAsList = []
for elem in l1:
  startRead = elem[0]
  endRead = elem[1]
  if startRead >= y1.shape[0]:
    startRead = y1.shape[0]-1
  if endRead >= y1.shape[0]:
    endRead = y1.shape[0]-1
  newWavFileAsList.extend(y1[startRead:endRead])


newWavFile = numpy.array(newWavFileAsList)

scipy.io.wavfile.write(outputName, fs1, newWavFile)