本文为大家分享了python实现录音小程序的具体代码,供大家参考,具体内容如下
学习目标:
学习电脑网从python实现录音小程序分析来看,对python实现录音小程序的结果。掌握python的pyaudio扩展包和Wave模块录制语音的方法
Wav音频:声道数,采样频率,量化位数
python Wav包是自带的,pyaudio需要下载
pip3 install pyaudio
python读Wav文件:
fp=wave.open('','rb')
nf=fp.getnframes()#获取文件的采样点数量
print('sampwidth:',fp.getsampwidth())
print('framerate:',fp.getframerate())
print('channels:',fp.getnchannels())
f_len=nf*2#文件长度计算,每个采样2个字节
audio_data=fp.readframes(nf)
python写Wav文件:
def save_wave_file(filename,data):
'''save the date to the wavfile'''
wf=wave.open(filename,'wb')
wf.setnchannels(channels)#声道
wf.setsampwidth(sampwidth)#采样字节 1 or 2
wf.setframerate(framerate)#采样频率 8000 or 16000
wf.writeframes(b"".join(data))#https://stackoverflow/questions/32071536/typeerror-sequence-item-0-expected-str-instance-bytes-found
wf.close()
利用PyAudio录音:
def my_record():
pa=PyAudio()
stream=pa.open(format = paInt16,channels=1,
rate=framerate,input=True,
frames_per_buffer=NUM_SAMPLES)
my_buf=[]
count=0
while count
string_audio_data = stream.read(NUM_SAMPLES)#一次性录音采样字节大小
my_buf.append(string_audio_data)
count+=1
print('.')
save_wave_file('01.wav',my_buf)
stream.close()
利用PyAudio播放音频
chunk=2014
def play():
wf=wave.open(r"01.wav",'rb')
p=PyAudio()
stream=p.open(format=p.get_format_from_width(wf.getsampwidth()),channels=
wf.getnchannels(),rate=wf.getframerate(),output=True)
while True:
data=wf.readframes(chunk)
if data=="":break
stream.write(data)
stream.close()
p.terminate()
完整录音播放的demo
import wave
from pyaudio import PyAudio,paInt16
framerate=8000
NUM_SAMPLES=2000
channels=1
sampwidth=2
TIME=2
def save_wave_file(filename,data):
'''save the date to the wavfile'''
wf=wave.open(filename,'wb')
wf.setnchannels(channels)
wf.setsampwidth(sampwidth)
wf.setframerate(framerate)
wf.writeframes(b"".join(data))
wf.close()
def my_record():
pa=PyAudio()
stream=pa.open(format = paInt16,channels=1,
rate=framerate,input=True,
frames_per_buffer=NUM_SAMPLES)
my_buf=[]
count=0
while count
string_audio_data = stream.read(NUM_SAMPLES)
my_buf.append(string_audio_data)
count+=1
print('.')
save_wave_file('01.wav',my_buf)
stream.close()
chunk=2014
def play():
wf=wave.open(r"01.wav",'rb')
p=PyAudio()
stream=p.open(format=p.get_format_from_width(wf.getsampwidth()),channels=
wf.getnchannels(),rate=wf.getframerate(),output=True)
while True:
data=wf.readframes(chunk)
if data=="":break
stream.write(data)
stream.close()
p.terminate()
if __name__ == '__main__':
my_record()
print('Over!')
play()
更多用法详见 pyaudio文档
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
更多:python怎么对矩阵添加一列python实现录音小程序
https://www.002pc.comhttps://www.002pc.com/python/379.html
你可能感兴趣的python,录音,程序,实现
挖矿的jsjquery imgareaselect 使用利用js与程序结合实现图片剪切
W WW.002PC .COM认为此文章对《jquery imgareaselect 使用利用js与程序结合实现图片剪切》说的很在理。
js电话号码nodejs获取微信小程序带参数二维码实现代码
nodejs获取微信小程序带参数二维码实现代码
由于项目需求,需要获取小程序页面的带有参数的二维码。好,那就看文档搞吧。
之前都是写前端,没有写过后台的东西,这次难得有机会组长
linux find 删除目录tac命令的实现
此程序实现简化的linux中的tac命令。即对文件按行倒序输出。电脑技术网对《linux find 删除目录tac命令的实现》总结来说,为我们程序员很实用。首先将文件指针置于文件尾,从后
js中大于小于等于小程序从手动埋点到自动埋点的实现方法
前言
小程序由于封闭性较强,要像web应用一样实现灵活的数据收集,会有一定难度。目前开源的埋点SDK,一般采用手动埋点的方式,这种方式有较强的侵入型,为了解决这个问题就有了该文
如何在字符串中间加换行符js微信小程序实现人脸识别
本文为大家分享了微信小程序人脸识别的具体代码,供大家参考,具体内容如下
首先,我们要有开发者工具,今天所说的是后端和前端联合起来实现的。
在PHP的控制器中写一个upload方法,
js 连mysql 延后Javascript实现页面无操作倒计时退出
项目前端页面需要实现,页面没人操作进入倒计时,以下为前端代码实现。W WW.002PC .COM对《Javascript实现页面无操作倒计时退出》总结来说,为我们程序交易很实用。
//设置(倒计
asp.net navigateurlc# 实现导出excel
c# 实现导出excel,有需要的朋友可以参考下。《asp.net navigateurlc# 实现导出excel》总结了关于程序员教程,对于我们来002pc.com确实能学到不少知识。
html使用asp.net.NET Core 3.0 可回收程序集加载上下文的实现
一、前世今生
.NET诞生以来,程序集的动态加载和卸载都是一个Hack的技术,之前的NetFx都是使用AppDomain的方式去加载程序集,然而AppDomain并没有提供直接卸载一个程序集的API,而
asp.net 底图asp.net中IDataParameter调用存储过程的实现方法
本文实例讲述了asp.net中IDataParameter调用存储过程的实现方法,是asp.net数据库程序设计中非常实用的技巧。分享给大家供大家参考。
php生成32位随机数PHP+Mysql+jQuery实现动态展示信息
在本站前面有文章介绍了如何实现发表微博说说:PHP+Mysql+jQuery实现发布微博程序--jQuery篇,本例将基于其数据库结构,用动态的方式展示发表的说说信息。
0踩
赏
0 赞