我的目标是通过笔记本电脑的麦克风录制我的声音,同时在 python 中为其添加效果。我需要的类似于音乐效果踏板,您可以在其中连接吉他或麦克风,并添加混响或回声或失真等。
我正在使用“pyaudio”和“wave”来录制和播放音频。使用 'scikits.audiolab' 将音频作为数组导入,并能够使用反转、剪辑、平铺等功能编辑此数组。音频数组的这种操作让我可以将效果“添加”到原始音频中。
我有一个问题,这不是一个真正的问题,它只是不是我想要的效果。假设我记录了“你好”这个词。我的记录功能设置为记录 3 秒。然后我把这个音频阵列平铺一次。现在,当我回放这个时,它会说 hello 两次,一个延迟效果。但是,两个问候之间有一个“空白空间”的时间间隔,这是因为在我打完招呼后音频仍在录制。因此,当它重复时,单词之间有太多的空白。我想消除这个空白空间,以便播放更快地说你好你好。
我的老师建议穿线。他说我应该记录,同时抓取前 500 个样本,说出一个数字。他建议在录制时采集这 500 个样本并播放它们。我不太确定如何实现这一点。
我的问题是,如何同时录制,获取前 500 个样本,并创建一个新数组,并将“效果”添加到原始录制中。
import scikits.audiolab as audiolab
import pyaudio
import wave
def recordAudio():
CHUNK = 1024
FORMAT = pyaudio.paInt16
CHANNELS = 1
RATE = 44100
RECORD_SECONDS = 3
WAVE_OUTPUT_FILENAME = "audioOriginal.wav"
p = pyaudio.PyAudio()
stream = p.open(format=FORMAT,
channels=CHANNELS,
rate=RATE,
input=True,
frames_per_buffer=CHUNK)
print("* recording:")
frames = []
for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):
data = stream.read(CHUNK)
frames.append(data)
print("* Finished recording.")
stream.stop_stream()
stream.close()
p.terminate()
wf = wave.open(WAVE_OUTPUT_FILENAME, 'wb')
wf.setnchannels(CHANNELS)
wf.setsampwidth(p.get_sample_size(FORMAT))
wf.setframerate(RATE)
wf.writeframes(b''.join(frames))
wf.close()
# Duplicate audio and save as Actual
frames, fs, encoder = audiolab.wavread('audioOriginal.wav')
audiolab.wavwrite(frames,'audioActual.wav',fs)
def playAudio():
import pyaudio
import wave
CHUNK = 1024
wf = wave.open('audioActual.wav', 'rb')
p = pyaudio.PyAudio()
stream = p.open(format=p.get_format_from_width(wf.getsampwidth()),
channels=wf.getnchannels(),
rate=wf.getframerate(),
output=True)
data = wf.readframes(CHUNK)
while data != '':
stream.write(data)
data = wf.readframes(CHUNK)
stream.stop_stream()
stream.close()
p.terminate()
def reverseAudio():
frames, fs, encoder = audiolab.wavread('audioActual.wav')
audiolab.wavwrite(frames[::-1],'audioActual.wav',44100)
def revert():
frames, fs, encoder = audiolab.wavread('audioOriginal.wav')
audiolab.wavwrite(frames,'audioActual.wav',fs)
def errorSelection():
print("\nERROR.") # no option in menu
def showMenu():
print("""
1. Record audio
2. Play audio
3. Reverse audio
4. Add delay
5. Revert to original audio
T to end program.
""")
# Menu
def main():
selecciones = {"1": recordAudio, "2": playAudio, "3": reverseAudio, "5": revert}
while True:
showMenu()
seleccion = raw_input(u'What do you want to do? ')
if "t" == seleccion:
return
elif "T" == seleccion:
return
toDo = selecciones.get(seleccion, errorSelection)
toDo()
if __name__ == "__main__":
main()