使用python进行波形及频谱绘制的方法


Posted in Python onJune 17, 2019

如下所示:

# -*- coding: UTF-8 -*-
import wave
import numpy as np
import matplotlib.pyplot as plt
 
# 打开wav文件 ,open返回一个的是一个Wave_read类的实例,通过调用它的方法读取WAV文件的格式和数据。
f = wave.open(r"D:\project\REC001.wav","rb")
# 读取格式信息
# 一次性返回所有的WAV文件的格式信息,它返回的是一个组元(tuple):声道数, 量化位数(byte单位), 采
# 样频率, 采样点数, 压缩类型, 压缩类型的描述。wave模块只支持非压缩的数据,因此可以忽略最后两个信息
params = f.getparams()
[nchannels, sampwidth, framerate, nframes] = params[:4]
# 读取波形数据
# 读取声音数据,传递一个参数指定需要读取的长度(以取样点为单位)
str_data = f.readframes(nframes)
f.close()
# 将波形数据转换成数组
# 需要根据声道数和量化单位,将读取的二进制数据转换为一个可以计算的数组
wave_data = np.fromstring(str_data,dtype = np.short)
# 将wave_data数组改为2列,行数自动匹配。在修改shape的属性时,需使得数组的总长度不变。
wave_data.shape = -1,2
# 转置数据
wave_data = wave_data.T
# 通过取样点数和取样频率计算出每个取样的时间。
time=np.arange(0,nframes/2)/framerate
# print(params)
plt.figure(1)
# time 也是一个数组,与wave_data[0]或wave_data[1]配对形成系列点坐标
plt.subplot(211)
plt.plot(time,wave_data[0])
plt.xlabel("time/s")
plt.title('Wave')
 
 
N=44100
start=0
# 开始采样位置
df = framerate/(N-1)
# 分辨率
freq = [df*n for n in range(0,N)]
# N个元素
wave_data2=wave_data[0][start:start+N]
c=np.fft.fft(wave_data2)*2/N
# 常规显示采样频率一半的频谱
plt.subplot(212)
plt.plot(freq[:round(len(freq)/2)],abs(c[:round(len(c)/2)]),'r')
plt.title('Freq')
plt.xlabel("Freq/Hz")
plt.show()

以上这篇使用python进行波形及频谱绘制的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python类参数self使用示例
Feb 17 Python
从源码解析Python的Flask框架中request对象的用法
Jun 02 Python
Python使用PDFMiner解析PDF代码实例
Mar 27 Python
详解Python map函数及Python map()函数的用法
Nov 16 Python
Python3实现的Mysql数据库操作封装类
Jun 06 Python
Python使用Selenium爬取淘宝异步加载的数据方法
Dec 17 Python
Python2.x与3​​.x版本有哪些区别
Jul 09 Python
python3中TQDM库安装及使用详解
Nov 18 Python
python 如何在测试中使用 Mock
Mar 01 Python
Python-typing: 类型标注与支持 Any类型详解
May 10 Python
yolov5返回坐标的方法实例
Mar 17 Python
浅析Python OpenCV三种滤镜效果
Apr 11 Python
PyQt5图形界面播放音乐的实例
Jun 17 #Python
PyQt5 在label显示的图片中绘制矩形的方法
Jun 17 #Python
PyQt5显示GIF图片的方法
Jun 17 #Python
详解pytorch 0.4.0迁移指南
Jun 16 #Python
对pyqt5多线程正确的开启姿势详解
Jun 14 #Python
Python+PyQT5的子线程更新UI界面的实例
Jun 14 #Python
在PYQT5中QscrollArea(滚动条)的使用方法
Jun 14 #Python
You might like
php jquery 多文件上传简单实例
2013/12/23 PHP
php验证码实现代码(3种)
2015/09/07 PHP
PHP策略模式定义与用法示例
2017/07/27 PHP
JavaScript 输入框内容格式验证代码
2010/02/11 Javascript
JQUERY 设置SELECT选中项代码
2014/02/07 Javascript
jQuery实现仿QQ在线客服效果的滚动层代码
2015/10/15 Javascript
JavaScript制作淘宝星级评分效果的思路
2020/06/23 Javascript
jquery实现可旋转可拖拽的文字效果代码
2016/01/27 Javascript
Angularjs使用指令做表单校验的方法
2017/03/31 Javascript
Vue.js 单页面多路由区域操作的实例详解
2017/07/17 Javascript
Node做中转服务器转发接口
2017/10/18 Javascript
详解JS浏览器事件循环机制
2019/03/27 Javascript
优雅地使用loading(推荐)
2019/04/20 Javascript
JavaScript页面倒计时功能完整示例
2019/05/15 Javascript
Vue 实现html中根据类型显示内容
2019/10/28 Javascript
react-native 实现购物车滑动删除效果的示例代码
2021/01/15 Javascript
Python使用Matplotlib实现Logos设计代码
2017/12/25 Python
python生成以及打开json、csv和txt文件的实例
2018/11/16 Python
linux下python中文乱码解决方案详解
2019/08/28 Python
OpenCV4.1.0+VS2017环境配置的方法步骤
2020/07/09 Python
Python实现迪杰斯特拉算法过程解析
2020/09/18 Python
css3 旋转按钮 使用CSS3创建一个旋转可变色按钮
2012/12/31 HTML / CSS
css3弹性盒模型(Flexbox)详细介绍
2014/10/08 HTML / CSS
HTML5通过navigator.mediaDevices.getUserMedia调用手机摄像头问题
2020/04/27 HTML / CSS
美国网上鞋城:Shoeline.com
2016/11/17 全球购物
世界汽车零件:World Car Parts
2019/09/04 全球购物
一加手机美国官方网站:OnePlus美国
2019/09/19 全球购物
你懂得怎么写自荐信吗?
2013/12/27 职场文书
电厂厂长岗位职责
2014/01/02 职场文书
超市5.1促销活动
2014/01/15 职场文书
敬老院院长事迹材料
2014/05/21 职场文书
道路施工安全责任书
2014/07/24 职场文书
领导班子个人对照检查剖析材料
2014/09/29 职场文书
欢迎词范文
2015/01/27 职场文书
个人催款函范文
2015/06/23 职场文书
浅谈spring boot使用thymeleaf版本的问题
2021/08/04 Java/Android