使用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 相关文章推荐
在RedHat系Linux上部署Python的Celery框架的教程
Apr 07 Python
Windows下Python的Django框架环境部署及应用编写入门
Mar 10 Python
Pycharm编辑器技巧之自动导入模块详解
Jul 18 Python
使用Python监视指定目录下文件变更的方法
Oct 15 Python
pycharm重置设置,恢复默认设置的方法
Oct 22 Python
python内存监控工具memory_profiler和guppy的用法详解
Jul 29 Python
Python for i in range ()用法详解
Sep 18 Python
在Mac中配置Python虚拟环境过程解析
Jun 22 Python
python实现xlwt xlrd 指定条件给excel行添加颜色
Jul 14 Python
谈谈python垃圾回收机制
Sep 27 Python
超级详细实用的pycharm常用快捷键
May 12 Python
Python将CSV文件转化为HTML文件的操作方法
Jun 30 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
Laravel5.5+ 使用API Resources快速输出自定义JSON方法详解
2020/04/06 PHP
jQuery toggle()设置CSS样式
2009/11/05 Javascript
JS获取dom 对象 ajax操作 读写cookie函数
2009/11/18 Javascript
解决jquery异步按一定的时间间隔刷新问题
2012/12/10 Javascript
js模拟滚动条(横向竖向)
2013/02/22 Javascript
jQuery模拟点击A标记示例参考
2014/04/17 Javascript
JavaScript加入收藏夹功能(兼容IE、firefox、chrome)
2014/05/05 Javascript
优化Node.js Web应用运行速度的10个技巧
2014/09/03 Javascript
jQuery实现图片文字淡入淡出效果
2015/12/21 Javascript
jQuery实现表格文本框淡入更改值后淡出效果
2016/09/27 Javascript
实例解析js中try、catch、finally的执行规则
2017/02/24 Javascript
vue2.0实现前端星星评分功能组件实例代码
2018/02/12 Javascript
Vue中如何实现proxy代理
2018/04/20 Javascript
jQuery阻止事件冒泡实例分析
2018/07/03 jQuery
一份超级详细的Vue-cli3.0使用教程【推荐】
2018/11/15 Javascript
js中的reduce()函数讲解
2019/01/18 Javascript
使用vue cli4.x搭建vue项目的过程详解
2020/05/08 Javascript
JavaScript图片旋转效果实现方法详解
2020/06/28 Javascript
vue 子组件修改data或调用操作
2020/08/07 Javascript
详解如何使用React Hooks请求数据并渲染
2020/10/18 Javascript
jQuery冲突问题解决方法
2021/01/19 jQuery
python求斐波那契数列示例分享
2014/02/14 Python
Python 使用SMTP发送邮件的代码小结
2016/09/21 Python
python3使用SMTP发送HTML格式邮件
2018/06/19 Python
详解pandas安装若干异常及解决方案总结
2019/01/10 Python
浅谈Python中eval的强大与危害
2019/03/13 Python
Python搭建代理IP池实现获取IP的方法
2019/10/27 Python
德国机场停车位比较和预订网站:Ich-parke-billiger
2018/01/08 全球购物
瑞典耳机品牌:URBANISTA
2019/12/03 全球购物
简单租房协议书
2014/04/09 职场文书
家长给学校的建议书
2014/05/15 职场文书
考试作弊被抓检讨书
2014/10/02 职场文书
赵氏孤儿观后感
2015/06/09 职场文书
工作感想范文
2015/08/07 职场文书
python实现过滤敏感词
2021/05/08 Python
彻底解决MySQL使用中文乱码的方法
2022/01/22 MySQL