Python 調用pyaudio庫錄制以及播放wav音頻文件


1.Pyaudio簡介

  PyAudio 是語音處理的 Python 庫,提供了比較豐富的功能。

2.功能

  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/`

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM