当前位置: 首页 > news >正文

做标书网站厦门网站建设服务

做标书网站,厦门网站建设服务,昌大建设集团地址,公司注册流程及资料python pyaudio实时读取音频数据并展示波形图 下面代码可以驱动电脑接受声音数据,并实时展示音波图: import numpy as np import matplotlib.pyplot as plt import matplotlib.animation as animation import pyaudio import wave import os import op…

python pyaudio实时读取音频数据并展示波形图

下面代码可以驱动电脑接受声音数据,并实时展示音波图:

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
import pyaudio
import wave
import os
import operator
from functools import reduceclass SubplotAnimation(animation.TimedAnimation):def __init__(self, static=False, path=None):"""音频波形动态显示,实时显示波形:param static: 是否为静态模式:param path:   wav 文件路径"""self.static = staticif static and os.path.isfile(path):self.stream = wave.open(path)# 采样频率self.rate = self.stream.getparams()[2]self.chunk = self.rate / 2self.read = self.stream.readframeselse:self.rate = 8000  # 采样率self.chunk = 200  # 语音块大小self.deviceindex = 0  # 录音设备编号p = pyaudio.PyAudio()# frames_per_buffer=self.chunk 设置音频流的缓冲区大小,即每次从音频设备读取的数据块的大小self.stream = p.open(format=pyaudio.paInt16, channels=1, rate=self.rate,input_device_index=self.deviceindex,input=True, frames_per_buffer=self.chunk)self.read = self.stream.readself.chunknum = 40  # 同屏显示语音块的数量self.voicedatas = []self.zero = [0 for i in range(self.chunk)]for index in range(self.chunknum):self.voicedatas.insert(0, self.zero)# 定义波形显示图的横纵坐标大小及类别并选用读取实时音频数据方式显示,设定更新间隔def start(self):fig = plt.figure()ax1 = fig.add_subplot(1, 1, 1)ax1.set_xlabel("t")ax1.set_ylabel("x")ax1.set_xlim(0, 1.0 * (self.chunknum * self.chunk - 1) / self.rate)ax1.set_ylim(-16000, 16000)self.line1, = ax1.plot([], [], lw=2)# 更新间隔/msinterval = int(1000 * self.chunk / self.rate)animation.TimedAnimation.__init__(self, fig, interval=interval, blit=True)# 初始化绘图,l.set_data([], []) 将绘图数据清空,使得动画开始时图像为空白状态def _init_draw(self):lines = [self.line1]for l in lines:l.set_data([], [])def new_frame_seq(self):return iter(range(self.chunk))def _draw_frame(self, framedata):if self.static:# 读取静态wav文件波形y = np.fromstring(self.read(self.chunk / 2 + 1), dtype=np.int16)[:-1]else:# 实时读取声频data = np.fromstring(self.read(self.chunk, exception_on_overflow=False), dtype=np.int16)data = data.tolist()self.voicedatas.append(data)self.voicedatas.pop(0)y = reduce(operator.add, self.voicedatas)  # 将 self.voicedatas 中的 40 个列表数据全部放在 1 个列表中x = np.linspace(0, 1.0 * (self.chunknum * self.chunk - 1) / self.rate, self.chunknum * self.chunk)# 画波形图self.line1.set_data(x, y)ani = SubplotAnimation()
ani.start()
plt.show()

在这里插入图片描述

http://www.yayakq.cn/news/988481/

相关文章:

  • 怎样免费建立自己网站网站建设四川推来客网站系统
  • 个人网站可以做百度竞价微信网站开发文档
  • 会展网站建设成功的原因威海北京网站建设
  • 漯河百度做网站电话旅游网站盈利模式怎么做
  • 扎区门户网站建设珠海建设银行官方网站
  • 中企动力建设网站自己建设外贸网站
  • 温州 建网站网站建设哪公司好
  • 如何把代码放在网站首页教程网页制作教程考拉
  • 海珠做网站公司黑龙江省建设安全教育信息网
  • 最全网站源码分享建设宁夏分行互联网站
  • 网站三层结构示意图漳州网站建设多少钱
  • 网站改标题降权什么是网站维护
  • 北海做网站的公司郑州app开发定制多少钱
  • 怎么做能收费的视频网站wordpress 不发邮件
  • 代理做减肥网站wordpress安装博客方法
  • 网站的系统建设方式网站 营销型
  • 网站建设电商开发人员工具
  • 网站开发怎样手机号验证国产最好的a级suv
  • 如何给网站做备案哪个网站做国内销海外的
  • 中源建设有限公司网站永州做网站费用
  • 做电影分享网站违法吗某网站网站的设计与实现
  • 网站后台 添加用户网络推广电话
  • aspnet网站开发实例佰联轴承网做的网站
  • 课程网站建设情况快手营销软件
  • 手机网站制作良心服务韩雪冬网站
  • 湖南企业建网站泉州住房和城乡建设部网站
  • 青岛网站制作设计中国质量建设协会网站
  • 任丘网站优化晋中推广型网站开发
  • 我国档案网站建设比较分析网站建设中 什么意思
  • 官方网站建设情况说明网站建设品牌策划