• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

python 通过麦克风录音 生成wav文件的方法

python 搞代码 4年前 (2022-01-08) 17次浏览 已收录 0个评论

今天小编就为大家分享一篇python 通过麦克风录音 生成wav文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

如下所示:

 #!/usr/bin/env python # -*- coding: utf-8 -*- ######################################################################## #  # Copyright (c) 2017 aibot.me, Inc. All Rights Reserved #  ########################################################################   """ File: gen_wav.py Date: 2017/03/24 12:36:27 Brief: 通过麦克风录音 生成 wav文件 """ import os import sys import wave import numpy as np  from datetime import datetime from pyaudio import PyAudio, paInt16 class GenAudio(object):     def __init__(self):         self.num_samples = 2000    #pyaudio内置缓冲大小         self.sampling_rate = 8000  #取样频率         self.level = 1500          #声音保存的阈值         self.count_num = 20        #count_num个取样之内出现COUNT_NUM个大于LEVEL的取样则记录声音         self.save_length = 8       #声音记录的最小长度:save_length * num_samples 个取样         self.time_count = 8        #录音时间,单位s         self.voice_string = []          #保存文件     def save_wav(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.close()               def read_audio(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                          # 读入num_samples个取样             string_audio_data = stream.read(self.num_samples)                  # 将读入的数据转换为数组             audio_data = np.fromstring(string_audio_data, dtype = np<b style="color:transparent">来源gao@!dai!ma.com搞$$代^@码!网</b>.short)             #计算大于 level 的取样的个数             large_sample_count = np.sum(audio_data > self.level)                          print(np.max(audio_data)),  "large_sample_count=>", large_sample_count             # 如果个数大于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_buffer.append(string_audio_data)             else:                 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         return True if __name__ == "__main__":     r = GenAudio()     r.read_audio()     r.save_wav("./test.wav") 

以上就是python 通过麦克风录音 生成wav文件的方法的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:python 通过麦克风录音 生成wav文件的方法
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址