好吧所以我也使用pyaudio但是从我看过的wave模块可能可以帮助我在这里。
所以我试图在我的程序中添加一个修剪功能,我的意思是我试图让用户找到一部分wav。他/她不喜欢并且有能力修剪波形文件但是他/她想要它。
到目前为止,我一直在使用pyaudio进行简单的播放,而对于从输入设备进行录制,pyaudio非常简单。我一直在搜索pyaudio我可以做什么来修剪音频,但我真的找不到任何可以帮助我的东西。虽然在嵌入式波模块上我看到有设置位置的方法。
我是否必须完成一个循环或if声明,以便程序知道要记录哪些位置,然后使用pyaudio或wave模块来记录用户设置位置(开头,结尾)的歌曲?如果我以这种方式接近它,我的程序会有效运行吗?
答案 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)