我需要从24位pcm格式的wav文件中读取数据,然后转换为float.我正在使用Python 2.7.2.
wave包以字符串形式读取数据,因此我尝试了以下操作:
import wave
import numpy as np
import array
import struct
f = wave.open('filename.wav')
# read in entire wav file
wdata = f.readframes(nFrames)
f.close()
# unpack into signed integers and convert to float
data = array.array('f')
for i in range(0,nFrames*3,3):
data.append(float(struct.unpack('<i', '\x00'+ wdata[i:i+3])[0]))
# normalize sample values
data = np.array(data)
data = data / 0x800000
这比我以前的方法要快很多,但仍然很慢.谁能建议一种更有效的方法?
解决方法:
这似乎相当快,它处理24位值,并进行规范化:
from scikits.audiolab import Sndfile
import numpy as np
f = Sndfile(fname, 'r')
data = np.array(f.read_frames(f.nframes), dtype=np.float64)
f.close()
return data