python音频处理的示例详解


Posted in Python onDecember 23, 2020

准备工作:
首先,我们需要 import 几个工具包,一个是 python 标准库中的 wave 模块,用于音频处理操作,另外两个是 numpy 和 matplot,提供数据处理函数。

一:读取本地音频数据

处理音频第一步是需要从让计算机“听到”声音,这里我们使用 python 标准库中自带的 wave模块进行音频参数的获取。

(1) 导入 wave 模块
(2) 使用 wave 中的函数 open 打开音频文件,wave.open(file,mode)函数带有两个参数, 第一个 file 是所需要打开的文件名及路径,使用字符串表示;第二个 mode 是打开的模式,也是用字符串表示 ('rb'或'wb')
(3) 打开音频后使用 getparams() 获取音频基本的相关参数(nchannels:声道数,
sampwidth:量化位数或量化深度,framerate:采样频率,nframes:采样点数)

# 导入 wave 模块
import wave
# 用于绘制波形图
import matplotlib.pyplot as plt
# 用于计算波形数据
import numpy as np
# 用于系统处理,如读取本地音频文件
import os
 
# 打开WAV文档
f = wave.open(r"2.wav",'rb' )
# 读取格式信息
params = f.getparams ()
nchannels,sampwidth, framerate, nframes = params [:4]
print(framerate)

二:读取单通道音频,并绘制波形图(常见音频为左右2个声道)

(1) 通过第一步,可以继续读取音频数据本身,保存为字符串格式

readframes:

读取声音数据,传递一个参数指定需要读取的长度(以取样点为单位),readframes返回的是二进制数据(一大堆bytes),在Python中用字符串表示二进制数据。

strData = f.readframes(nframes)

(2) 如果需要绘制波形图,则需要将字符串格式的音频数据转化为 int 类型

frombuffer:

根据声道数和量化单位,将读取的二进制数据转换为一个可以计算的数组。

通过frombuffer函数将二进制转换为整型数组,通过其参数dtype指定转换后的数据格式。

waveData=np.frombuffer(strData,dtype=np.int16)

此处需要使用到 numpy 进行数据格式的转化

(3) 将幅值归一化
把数据变成(0,1)之间的小数。主要是为了数据处理方便提出来的,把数据映射到0~1范围之内处理,更加便捷快速。

waveData=waveData*1.0/(max(abs(waveData)))

这一步去掉也可画出波形图,可以尝试不用此步,找出波形图的不同

(4) 绘制图像

通过取样点数和取样频率计算出取样的时间:

time = np.arange(0,nframes)*(1.0/framerate)

import wave
# 导入 wave 模块
import matplotlib.pyplot as plt
# 用于绘制波形图
import numpy as np
# 用于计算波形数据
import os
#  用于系统处理,如读取本地音频文件
 
f = wave.open(r"di.wav",'rb' )
params = f.getparams ()
nchannels,sampwidth, framerate, nframes = params [:4]
print(framerate)
 
# 读取波形数据
strData = f.readframes(nframes)
# 将字符串转换为16位整数
waveData = np.frombuffer(strData,dtype=np.int16)
# 幅值归一化
waveData = waveData*1.0/(max(abs(waveData)))
#计算音频的时间
time = np.arange(0,nframes)*(1.0 / framerate)
 
plt.plot(time,waveData)
plt.xlabel("Time(s)")
plt.ylabel("Amplitude") 
plt.title("Single channel wavedata")
plt.show()

效果图

python音频处理的示例详解

到此这篇关于python音频处理的示例详解的文章就介绍到这了,更多相关python音频处理内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
编写Python脚本把sqlAlchemy对象转换成dict的教程
May 29 Python
Python的净值数据接口调用示例分享
Mar 15 Python
Python面向对象编程中关于类和方法的学习笔记
Jun 30 Python
python利用正则表达式排除集合中字符的功能示例
Oct 10 Python
Python数据分析中Groupby用法之通过字典或Series进行分组的实例
Dec 08 Python
kaggle+mnist实现手写字体识别
Jul 26 Python
python的xpath获取div标签内html内容,实现innerhtml功能的方法
Jan 02 Python
Python实现去除列表中重复元素的方法总结【7种方法】
Feb 16 Python
Python Django 实现简单注册功能过程详解
Jul 29 Python
Python基本类型的连接组合和互相转换方式(13种)
Dec 16 Python
Python+OpenCV实现将图像转换为二进制格式
Jan 09 Python
python中24小时制转换为12小时制的方法
Jun 18 Python
python 实现客户端与服务端的通信
Dec 23 #Python
python实现excel公式格式化的示例代码
Dec 23 #Python
python 基于opencv实现图像增强
Dec 23 #Python
python接口自动化框架实战
Dec 23 #Python
pycharm远程连接服务器并配置python interpreter的方法
Dec 23 #Python
python实现发送QQ邮件(可加附件)
Dec 23 #Python
如何通过安装HomeBrew来安装Python3
Dec 23 #Python
You might like
PHP读取mssql json数据中文乱码的解决办法
2016/04/11 PHP
php7 新增功能实例总结
2020/05/25 PHP
Javascript attachEvent传递参数的办法
2009/12/14 Javascript
formvalidator验证插件中有关ajax验证问题
2013/01/04 Javascript
jQuery回车实现登录简单实现
2013/08/20 Javascript
解决Jquery鼠标经过不停滑动的问题
2014/03/03 Javascript
javascript实现别踩白块儿小游戏程序
2015/11/22 Javascript
BootStrap实现树形目录组件代码详解
2016/06/21 Javascript
Bootstrap table使用方法详细介绍
2016/12/09 Javascript
微信小程序 label 组件详解及简单实例
2017/01/10 Javascript
jQuery修改DOM结构_动力节点Java学院整理
2017/07/05 jQuery
Vue的Flux框架之Vuex状态管理器
2017/07/30 Javascript
利用nodeJs anywhere搭建本地服务器环境的方法
2018/05/12 NodeJs
select2 ajax 设置默认值,初始值的方法
2018/08/09 Javascript
解决vue的过渡动画无法正常实现问题
2019/10/31 Javascript
2分钟实现一个Vue实时直播系统的示例代码
2020/06/05 Javascript
[02:17]TI4西雅图DOTA2前线报道 啸天mik夫妻档解说
2014/07/08 DOTA
利用Python中的pandas库对cdn日志进行分析详解
2017/03/07 Python
python实现百万答题自动百度搜索答案
2018/01/16 Python
django解决跨域请求的问题
2018/11/11 Python
Django实现一对多表模型的跨表查询方法
2018/12/18 Python
Python文件操作中进行字符串替换的方法(保存到新文件/当前文件)
2019/06/28 Python
python绘制BA无标度网络示例代码
2019/11/21 Python
python 如何区分return和yield
2020/09/22 Python
HTML5 Canvas+JS控制电脑或手机上的摄像头实例
2014/05/03 HTML / CSS
利用Storage Event实现页面间通信的示例代码
2018/07/26 HTML / CSS
Priority Pass机场贵宾室会籍计划:全球超过1200间机场贵宾室
2018/08/26 全球购物
俄罗斯一家时尚女装商店:Charuel
2019/12/04 全球购物
求职简历自我评价范例
2014/03/12 职场文书
大学优秀班主任事迹材料
2014/05/02 职场文书
上海世博会志愿者口号
2014/06/17 职场文书
2014年创先争优工作总结
2014/12/11 职场文书
事业单位考察材料范文
2014/12/25 职场文书
毕业生学校组织意见
2015/06/04 职场文书
《平移和旋转》教学反思
2016/02/19 职场文书
《草船借箭》教学反思
2016/02/23 职场文书