IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> python音频初步:通过wave模块处理wav格式的音频 -> 正文阅读

[人工智能]python音频初步:通过wave模块处理wav格式的音频

一个小例子

wave用于处理wav格式的音频数据,支持单声道/立体声。

先看一个简单的示例

import wave
wavRead = wave.open('test.wav','rb')    #读取音频
params = wavRead.getparams()          #获取音频信息
print(params)
# 其值如下,分别表示通道数为2, 采样位宽为2, 帧率48k,帧数16291840,无压缩
# _wave_params(nchannels=2, sampwidth=2, framerate=48000, 
# nframes=16291840, comptype='NONE', compname='not compressed')
wavWrite = wave.open('new.wav','wb')    #新建一个wav文件
wavWrite.setparams(params)              #设置音频参数
segment = wavRead.readframes(1629184)     #从test.wav中读取1629184帧
wavWrite.writeframes(segment)           #将音频片段写入new.wav
wavRead.close()     #关闭文件
wavWrite.close()

在运行完上面的代码后,可以看到工作路径下多出一个new.wav,大小差不多是test.wav的十分之一左右,即成功对test.wav进行了分割。

其中wave.open用于打开音频文件,当模式为rb时,表示只读;wb为只写。只读模式下,返回一个Wave_read对象;只写模式下,返回Wave_write的实例。

读:Wave_read

除了用于关闭音频文件的close()之外,只读模式返回的Wave_read对象中封装了许多无参函数,用以获取音频数据的信息。

getnchannels()返回声道数量,1为单声道,2为立体声
getsampwidth()返回字节长度
getframerate()返回采样频率
getnframes()返回音频总帧数
getcomptype()
getcompname()
返回压缩类型,然鹅只能是None
getparams()返回一个元组,内容包括上面五项

接下来,是Wave_read的核心功能——readframes(n)。通过该方法,可以读取并返回以bytes对象表示的最多n帧音频。

在读取n帧之后,数据流的指针也会跳到n处,通过tell()函数可以返回当前指针位置。若想让指针重新回到文件开始,可实用rewind();通过setpos(n),可以让指针跳到n处。

写:Wave_write

Wave_read中的get相对应,Wave_write中除了也提供get方法之外,也提供一些set方法,用于设置相关的信息

getsetset功能
getnchannels()setnchannels(n)设置声道数量
getsampwidth()setsampwidth(n)设置字节长度为n
getframerate()setframerate(n)设置采样频率为n
getnframes()setnframes(n)设置音频总帧数为n
getcompname()
getcomptype()
setcomptype(type,name)设置压缩格式,然鹅只能是None
getparams()setparams(tuple)设置上面的那些内容

接下来,与Wave_read.readframes()针锋相对的函数为writeframes(data),用于写入音频数据,其中data为bytes格式的二进制数据。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-12-10 11:04:02  更:2021-12-10 11:05:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 23:24:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码