1.Pyaudio簡介
PyAudio 是語音處理的 Python 庫,提供了比較豐富的功能。
python的Pyaud模塊可以調用電腦的麥克風或音響進行錄音,音頻播放,生成wav文件等。
wave是錄音是用的標准的WINDOWS文件格式,擴展名為WAV,數據本身的格式為PCM或壓縮型,屬於無損音樂格式的一種。
3.Pyaudio安裝
pip install pyaudio
推薦使用清華源哦,速度快
pip install pyaudio -i https://pypi.tuna.tsinghua.edu.cn/simple
4.使用Pyaudio進行錄音
導入所需庫
import wave import pyaudio def audio_record(out_file, rec_time): CHUNK = 1024 FORMAT = pyaudio.paInt16 # 16bit編碼格式 CHANNELS = 1 # 單聲道 RATE = 16000 # 16000采樣頻率 p = pyaudio.PyAudio() # 創建音頻流 stream = p.open(format=FORMAT, # 音頻流wav格式 channels=CHANNELS, # 單聲道 rate=RATE, # 采樣率16000 input=True, frames_per_buffer=CHUNK) print("開始錄制。。。") frames = [] # 錄制的音頻流 # 錄制音頻數據 for i in range(0, int(RATE / CHUNK * rec_time)): data = stream.read(CHUNK) frames.append(data) # 錄制完成 stream.stop_stream() stream.close() p.terminate() print("完成。。。。。")
將它封裝成函數,直接去調用,函數的參數分別為文件名稱和錄制時間。
5.使用Pyaudio庫播放錄音
import wave import pyaudio def play(): chunk = 1024 wf = wave.open(r"文件名", '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) # 讀取數據 print(data) while data != b'': # 播放 stream.write(data) data = wf.readframes(chunk) print('while循環中!') print(data) stream.stop_stream() # 停止數據流 stream.close() p.terminate() # 關閉 PyAudio play()
跟多內容參考官方文檔`http://people.csail.mit.edu/hubert/pyaudio/docs/`
