wav文件格式及ffmpeg处理命令
wav文件头详解
符合RIFF(Resource Interchange File Format)规范的wav文件的文件头记录了音频流的编码参数等基本信息。wav文件由多个块组成,至少包含RIFF标志块、格式块、数据头块和数据块,所有数据均以小端模式存储。(小端模式:按顺序读取时,先读取的是数据的低位部分,后读取的是数据的高位部分。如数据0x11, 0x00代表的是十六进制数0x0011,也就是3)。
一般的wav文件头由以下数据组成:
| 偏移地址 | 字节数 | 数据类型 | 内容 |
| 00H ~ 03H | 4 | char | "RIFF", 资源交换文件RIFF标志,固定不变 |
| 04H ~ 07H | 4 | long |
文件长度,从下个字节开始到文件结束的总字节数。 计算结果为文件大小(可以从文件属性中看)+8个字节(00H~07H) |
| 08H ~ 0BH | 4 | char | "WAVE", WAVE文件标志,固定不变 |
| 0CH ~ 0FH | 4 | char | "fmt ", fmt标志(最后一位为空格),固定不变 |
| 10H ~ 13H | 4 | long | 格式长度,一般为00000010H(=16),代表16PCM(量化结果为16bit) |
| 14H ~ 15H | 2 | int | 格式类别,1表示线性PCM编码 |
| 16H ~ 17H | 2 | int | 通道数,1为单声道,2为双声道 |
| 18H ~ 1BH | 4 | long | 采样频率(每秒的样本数) |
| 1CH ~ 1FH | 4 | long | 每秒字节数,其值为:采样频率*通道数*样本数据位数/8 |
| 20H ~ 21H | 2 | int | DATA数据块的调整数(字节),其值为:通道数*样本数据位数/8 |
| 22H ~ 23H | 2 | int | 样本数据位数,0010H即16,代表一个量化两本占2字节 |
| 24H ~ 27H | 4 | char | "data", data数据块标志,固定不变 |
| 28H ~ 2BH | 4 | long | wav文件音频数据所占大小 |
| 2CH ~ ... | ... | 真正存储的音频数据(不属于文件头了) |
上面是一般wav文件的文件头数据,而通过ffmpeg转码的wav文件于此有些差距,在格式块和数据头块之间添加了一些ffmpeg的信息,如下图。

| 偏移地址 | 字节数 | 数据类型 | 内容 |
| 00H ~ 23H | 36 | 同上表的00H~23H一致 | |
| 24H ~ 27H | 4 | char | "LIST", LIST块标志,固定不变 |
| 28H ~ 2BH | 4 | long | LIST块占用的字节数,在这里为26字节 |
| 2CH ~ 45H | 26 | LIST块内容 | |
| 46H ~ 49H | 4 | char | "data", data数据块标志,固定不变 |
| 4AH ~ 4DH | 4 | long | wav文件音频数据所占大小 |
ffmpeg处理命令
1. 将格式不正确的wav文件转码为ffmpeg格式的wav文件:
ffmpeg -i "sourceFile" -y "targetFile"
2. 将mp3文件转码为ffmpeg格式的wav文件(编码格式为16PCM、小端模式):
ffmpeg -i "sourceFile" -acodec pcm_s16le -y "targetFile"
3. 音频切割:
ffmpeg -i "sourceFile" -ss startTime -to endTime -y "targetFile"(按起点和终点切割)
ffpmeg -i "sourceFile" -ss startTime -t duration -y "targetFile"(按起点和持续时间切割)
参考文章
1. WAV文件格式
2. wav文件详解
3. wav文件格式分析
wav文件格式及ffmpeg处理命令的更多相关文章
- 转: FFmpeg功能命令汇总
原文: FFmpeg功能命令汇总 前言 如此强大的FFmpeg,能够实现视频采集.视频格式转化.视频截图.视频添加水印.视频切片.视频录制.视频推流.更改音视频参数功能等.通过终端命令如何实现这些功能 ...
- FFmpeg常用命令 (三)流媒体
前言 如此强大的FFmpeg,能够实现视频采集.视频格式转化.视频截图.视频添加水印.视频切片.视频录制.视频推流.更改音视频参数功能等.通过终端命令如何实现这些功能,Richy在本文做一记录,以备之 ...
- WAV文件格式
作者:阿宝 更新:2016-09-21 来源:彩色世界(https://blog.hz601.org/2016/09/21/waveform-audio-file-format/index.html) ...
- FFmpeg常用命令学习笔记(二)录制命令
录制命令 1.FFmpeg录屏命令 ffmpeg -f avfoundation -i 1 -r 30 out.yuv -f:指定使用avfoundation采集数据 -i:指定从哪采集数据,它是一个 ...
- 音频相关 ALSA ffmpeg ffplay 命令用法 g7xx
采样率: samples 441100 每秒 DAC/ADC 采样的频率,声卡一般还支持 48k 8k 等模式. 通道:channels 2声道 左右声道 也有单声道的声音,5.1 声道 位数: 16 ...
- wav文件格式分析详解
wav文件格式分析详解 文章转载自:http://blog.csdn.net/BlueSoal/article/details/932395 一.综述 WAVE文件作为多媒体中使用的声波文件格式 ...
- WAV文件格式分析
一. RIFF概念 在Windows环境下,大部分的多媒体文件都依循着一种结构来存放信息,这样的结构称为"资源互换文件格式"(Resources lnterchange File ...
- FFmpeg 常用命令收集
FFmpeg 常用命令 合并视频 ffmpeg -i "KTDS-820A_FHD.mp4" -c copy -bsf:v h264_mp4toannexb -f mpegts i ...
- wav文件格式分析与详解
WAV文件是在PC机平台上很常见的.最经典的多媒体音频文件,最早于1991年8月出现在Windows 3.1操作系统上,文件扩展名为WAV,是WaveFom的简写,也称为波形文件,可直接存储声音波形, ...
随机推荐
- P4安装
P4安装篇 ubuntu 14.04为例子 一.首先要fork到自己的github里面 源码目录 https://github.com/p4lang/p4factory 然后fork到自己的githu ...
- TCP/IP Illustrated Vol1 Second Edition即英文版第二版,TCP部分个人勘误
目前已经有了英文版第二版的TCPIP详解,中文版暂时还没有,但是英文版还是有好几处错误,作者和官方竟然没有维护一个勘误表. 个人阅读过程中针对TCP部分可能有问题的地方简单勘误一下 P596:示意图中 ...
- Prism6下的MEF:第一个Hello World
最近看书比较多,正好对过去几年的软件开发做个总结.写这个的初衷只是为了简单的做一些记录. 前言 复杂的应用程序总是面临很多的页面之间的数据交互,怎样创建松耦合的程序一直是多数工程师所思考的问题.诸如依 ...
- 区别mouseover与mouseenter?
区别mouseover与mouseenter? * mouseover: 在移入子元素时也会触发, 对应mouseout,进入子元素的时候,父元素显示离开状态 * mouseenter: 只在移入当前 ...
- 6/7 sprint2 看板和燃尽图的更新
- cxgrid中,如何根据列名或字段名取得footer值
注意,不是根据index取得footer值cxgrdtbv1.DataController.Summary.FooterSummaryValues[0]; ------解决方案------------ ...
- 命令行执行python文件时提示ImportError: No module named 'xxx'
背景: 最近在写接口自动化测试框架的时候发现,框架使用pycharm ide的时候可以正常跑测试用例,但是在dos窗口输入命令执行测试的时候,import项目内部的包时报错“ModuleNotFoun ...
- 命令行方式操作O365
这几天公司为O365启用了双因子认证,期间出了些小问题,导致我无法使用管理员账号登入控制台,但是Powershell的方法依旧可以.所以我觉得还是有必要把图形化操作改成脚本操作,以备不时之需.以后凡是 ...
- [转帖]七牛云对HTTPS 的解释
感觉对RTT 还有 建立连接的说明挺好的 转帖一下 学习 https://www.cnblogs.com/qiniu/p/6856012.html 序•魔戒再现 几天前,OpenSSL ...
- Rotate Array II
Rotate an array of n elements to the right by k steps. For example, with n = 7 and k = 3, the array ...