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

作者:匠子的窝 时间:2023-02-07 02:48:58 

如下所示:


# -*- 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()

来源:https://blog.csdn.net/sinat_29242905/article/details/86499907

标签:python,波形,频谱,绘制
0
投稿

猜你喜欢

  • Python输入整数进行排序方式

    2023-05-14 11:03:15
  • mysql数据库优化总结(心得)

    2024-01-17 17:50:37
  • MySQL 事务概念与用法深入详解

    2024-01-14 02:56:06
  • MySQL数据库索引以及失效场景详解

    2024-01-26 04:12:23
  • 用asp编写类似搜索引擎功能的代码

    2008-10-23 15:55:00
  • Python实现矩阵加法和乘法的方法分析

    2023-07-30 09:39:06
  • python修改文件内容的3种方法详解

    2021-07-27 10:19:36
  • python itertools包内置无限迭代器

    2023-11-16 18:58:59
  • html元素input使用方法

    2007-12-06 13:02:00
  • 关于Python OS模块常用文件/目录函数详解

    2023-07-04 06:30:06
  • 彻底卸载MySQL的方法分享

    2024-01-23 11:49:08
  • Python对象与json数据的转换问题实例详解

    2023-10-27 22:08:39
  • python实现计算资源图标crc值的方法

    2022-07-02 17:57:56
  • javascript发表评论或者留言时的展开效果

    2024-05-02 17:29:19
  • 详解CSS的优先权

    2008-05-11 18:57:00
  • 浅析Python 3 字符串中的 STR 和 Bytes 有什么区别

    2021-02-20 00:51:59
  • js 替换功能函数,用正则表达式解决,js的全部替换

    2024-04-17 09:56:35
  • Python包,__init__.py功能与用法分析

    2021-06-17 22:19:54
  • 利用django model save方法对未更改的字段依然进行了保存

    2021-12-21 21:24:18
  • python游戏测试工具自动化遍历游戏中所有关卡

    2021-10-05 13:03:20
  • asp之家 网络编程 m.aspxhome.com