本文執行個體講述了python處理位元據的方法。分享給大家供大家參考。具體如下:
#!/usr/env/env python #-*- coding: cp936 -*- ''''' 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程式設計有所協助。