python调⽤pyaudio使⽤麦克风录制wav声⾳⽂件的教程
python的pyaudio可以进⾏录⾳,播放,⽣成wav⽂件等等,WAVE是录⾳时⽤的标准的WINDOWS⽂件格式,⽂件的扩展名为WAV,数据本⾝的格式为PCM或压缩型,属于⽆损⾳乐格式的⼀种。在我们研究语⾳识别,⾃然语⾔处理的过程中,常常会使⽤到它,⽐如我们调⽤百度语⾳识别所以我们⾸先研究⼀下pyaudio库的安装与使⽤。
安装:python怎么读取py文件
pip install pyaudio
调⽤pyaudio使⽤麦克风录制声⾳:
python中的pyaudio库可以直接通过麦克风录制声⾳,我们可以通过调⽤该库,获取到wav测试语⾳。具体代码如下所⽰:#!/usr/bin/python3
# -*- coding: utf-8 -*-
from pyaudio import PyAudio, paInt16
import numpy as np
from datetime import datetime
import wave
class recoder:
NUM_SAMPLES = 2000 #pyaudio内置缓冲⼤⼩
SAMPLING_RATE = 8000 #取样频率
LEVEL = 500 #声⾳保存的阈值
COUNT_NUM = 20 #NUM_SAMPLES个取样之内出现COUNT_NUM个⼤于LEVEL的取样则记录声⾳
SAVE_LENGTH = 8 #声⾳记录的最⼩长度:SAVE_LENGTH * NUM_SAMPLES 个取样
TIME_COUNT = 60 #录⾳时间,单位s
Voice_String = []
def savewav(self,filename):
wf = wave.open(filename, 'wb')
wf.setnchannels(1)
wf.setsampwidth(2)
wf.setframerate(self.SAMPLING_RATE)
wf.writeframes(np.array(self.Voice_String).tostring())
# wf.writeframes(self.Voice_String.decode())
wf.close()
def recoder(self):
pa = PyAudio()
stream = pa.open(format=paInt16, channels=1, rate=self.SAMPLING_RATE, input=True,
frames_per_buffer=self.NUM_SAMPLES)
save_count = 0
save_buffer = []
time_count = self.TIME_COUNT
while True:
time_count -= 1
# print time_count
# 读⼊NUM_SAMPLES个取样
string_audio_data = ad(self.NUM_SAMPLES)
# 将读⼊的数据转换为数组
audio_data = np.fromstring(string_audio_data, dtype=np.short)
# 计算⼤于LEVEL的取样的个数
large_sample_count = np.sum( audio_data > self.LEVEL )
print(np.max(audio_data))
# 如果个数⼤于COUNT_NUM,则⾄少保存SAVE_LENGTH个块
if large_sample_count > self.COUNT_NUM:
save_count = self.SAVE_LENGTH
else:
save_count -= 1
if save_count < 0:
save_count = 0
if save_count > 0 :
# 将要保存的数据存放到save_buffer中
#print save_count > 0 and time_count >0
save_buffer.append( string_audio_data )
else:
#print save_buffer
# 将save_buffer中的数据写⼊WAV⽂件,WAV⽂件的⽂件名是保存的时刻
#print "debug"
if len(save_buffer) > 0 :
self.Voice_String = save_buffer
save_buffer = []
print("Recode a piece of voice successfully!")
return True
if time_count==0:
if len(save_buffer)>0:
self.Voice_String = save_buffer
save_buffer = []
print("Recode a piece of voice successfully!")
return True
else:
return False
if __name__ == "__main__":
r = recoder()
r.savewav("test.wav")
总结
以上所述是⼩编给⼤家介绍的python调⽤pyaudio使⽤麦克风录制wav声⾳⽂件的教程,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论