时间:2021-05-22
如下所示:
''''' add Head Infomation for pcm file '''import sys import struct import os __author__ = 'bob_hu, hewitt924@gmail.com'__date__ = 'Dec 19,2011'__update__ = 'Dec 19,2011'def geneHeadInfo(sampleRate,bits,sampleNum): ''''' 生成头信息,需要采样率,每个采样的位数,和整个wav的采样的字节数 ''' rHeadInfo = '\x52\x49\x46\x46' fileLength = struct.pack('i',sampleNum + 36) rHeadInfo += fileLength rHeadInfo += '\x57\x41\x56\x45\x66\x6D\x74\x20\x10\x00\x00\x00\x01\x00\x01\x00' rHeadInfo += struct.pack('i',sampleRate) rHeadInfo += struct.pack('i',sampleRate * bits / 8) rHeadInfo += '\x02\x00' rHeadInfo += struct.pack('H',bits) rHeadInfo += '\x64\x61\x74\x61' rHeadInfo += struct.pack('i',sampleNum) return rHeadInfo if __name__ == '__main__': if len(sys.argv) != 5: print "usage: python %s inFile sampleRate bits outFile" % sys.argv[0] sys.exit(1) fout = open(sys.argv[4],'wb') #用二进制的写入模式 #fout.write(struct.pack('4s','\x66\x6D\x74\x20')) #写入一个长度为4的串,这个串的二进制内容为 66 6D 74 20 #Riff_flag,afd,fad,afdd, = struct.unpack('4c',fin.read(4)) #读入四个字节,每一个都解析成一个字母 #open(sys.argv[4],'wb').write(struct.pack('4s','fmt ')) #将字符串解析成二进制后再写入 #open(sys.argv[4],'wb').write('\x3C\x9C\x00\x00\x57') #直接写入二进制内容:3C 9C 00 00 57 #fout.write(struct.pack('i',6000)) #写入6000的二进制形式 #check whether inFile has head-Info fin = open(sys.argv[1],'rb') Riff_flag, = struct.unpack('4s',fin.read(4)) if Riff_flag == 'RIFF': print "%s 有头信息" % sys.argv[1] fin.close() sys.exit(0) else: print "%s 没有头信息" % sys.argv[1] fin.close() #采样率 sampleRate = int(sys.argv[2]) #bit位 bits = int(sys.argv[3]) fin = open(sys.argv[1],'rb') startPos = fin.tell() fin.seek(0,os.SEEK_END) endPos = fin.tell() sampleNum = (endPos - startPos) print sampleNum headInfo = geneHeadInfo(sampleRate,bits,sampleNum) fout.write(headInfo) fin.seek(os.SEEK_SET) fout.write(fin.read()) fin.close() fout.close()以上这篇python pcm音频添加头转成Wav格式文件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言本文主要记录python下音频常用的操作,以.wav格式文件为例。其实网上有很多现成的音频工具包,如果仅仅调用,工具包是更方便的。更多pyton下的操作可以
最近使用Python调用百度的RESTAPI实现语音识别,但是百度要求音频文件的压缩方式只能是pcm(不压缩)、wav、opus、speex、amr,这里面也就
本文为大家分享了python实现大音频文件语音识别功能的具体代码,供大家参考,具体内容如下实现思路:先用ffmpeg将其他非wav格式的音频转换为wav格式,并
数字音频输出pcm的意思是脉冲编码调制(PulseCodeModulation,PCM),脉码调制的音频格式也被DVD-A所采用,它支持立体声和5.1环绕声,1
以电脑为例,声音格式文件存储空间较大是因为一般默认的存储格式是wav和APE、FLAC,都是属于无损坏的,所以文件比较大。而平时用的mp3或其他的音乐格式大多是