wav音频

wav是微软开发的一种音频文件格式,注意,wav文件格式是无损音频文件格式,相对于其他音频格式文件数据是没有经过压缩的,通常文件也相对比较大些。

文件格式如图所示:


#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>


struct WAV_Format {
uint32_t ChunkID; /* "RIFF" */
uint32_t ChunkSize; /* 36 + Subchunk2Size */
uint32_t Format; /* "WAVE" */


/* sub-chunk "fmt" */
uint32_t Subchunk1ID; /* "fmt " */
uint32_t Subchunk1Size; /* 16 for PCM */
uint16_t AudioFormat; /* PCM = 1*/
uint16_t NumChannels; /* Mono = 1, Stereo = 2, etc. */
uint32_t SampleRate; /* 8000, 44100, etc. */
uint32_t ByteRate; /* = SampleRate * NumChannels * BitsPerSample/8 */
uint16_t BlockAlign; /* = NumChannels * BitsPerSample/8 */
uint16_t BitsPerSample; /* 8bits, 16bits, etc. */


/* sub-chunk "data" */
uint32_t Subchunk2ID; /* "data" */
uint32_t Subchunk2Size; /* data size */
}; 


int main(void)
{
FILE *fp = NULL;
struct WAV_Format wav;


fp = fopen("test.wav", "rb");
if (!fp) {
printf("can't open audio file\n");
exit(1);
}


fread(&wav, 1, sizeof(struct WAV_Format), fp);


printf("ChunkID \t%x\n", wav.ChunkID);
printf("ChunkSize \t%d\n", wav.ChunkSize);
printf("Format \t\t%x\n", wav.Format);
printf("Subchunk1ID \t%x\n", wav.Subchunk1ID);
printf("Subchunk1Size \t%d\n", wav.Subchunk1Size);
printf("AudioFormat \t%d\n", wav.AudioFormat);
printf("NumChannels \t%d\n", wav.NumChannels);
printf("SampleRate \t%d\n", wav.SampleRate);
printf("ByteRate \t%d\n", wav.ByteRate);
printf("BlockAlign \t%d\n", wav.BlockAlign);
printf("BitsPerSample \t%d\n", wav.BitsPerSample);
printf("Subchunk2ID \t%x\n", wav.Subchunk2ID);
printf("Subchunk2Size \t%d\n", wav.Subchunk2Size);


fclose(fp);


return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Python截取WAV音频,你可以按照以下步骤进行操作: 1. 导入必要的库:使用Python的wave库来读取WAV文件。 2. 打开WAV文件:使用wave.open()函数打开指定的WAV文件。 3. 获取音频信息:通过读取WAV文件的getparams()方法来获取音频的参数信息,如采样频率、声道数等。 4. 设置截取的起止时分秒:根据需要,设置起止时分秒来确定要截取的音频段落。 5. 计算截取的帧数:根据音频的采样率和设置的起止时分秒,计算出对应的帧数范围。 6. 设置输出音频信息:根据需要,设置截取出来的音频的名称、专辑名称、歌手名称等信息。 7. 创建输出音频文件:使用wave.open()函数创建一个新的WAV文件来存储截取出来的音频。 8. 读取并写入截取的音频数据:使用WAV文件的readframes()方法读取指定范围的音频帧,并使用writeframes()方法将这些帧写入到新的WAV文件中。 9. 关闭文件:使用WAV文件的close()方法关闭输入和输出文件。 以下是一个示例代码,演示了如何使用Python截取WAV音频: ```python import wave # 打开WAV文件 input_file = wave.open("input.wav", "rb") output_file = wave.open("output.wav", "wb") # 获取音频信息 params = input_file.getparams() # 设置截取的起止时分秒 start_time = 0 # 设置起始时间(秒) end_time = 10 # 设置结束时间(秒) # 计算截取的帧数 start_frame = int(start_time * params.framerate) end_frame = int(end_time * params.framerate) # 设置输出音频信息 output_file.setparams(params) # 创建输出音频文件 output_file.writeframes(input_file.readframes(start_frame)) output_file.writeframes(input_file.readframes(end_frame - start_frame)) # 关闭文件 input_file.close() output_file.close() ``` 请注意,上述示例代码仅展示了截取WAV音频的基本步骤,你可以根据实际需求进行更进一步的处理和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值