【python】二进制文件读取
在matlab中,通过命令:A=fread(fileID,sizeA,precision,skip,machinefmt) ;读取,其中precision 需要读取数据的类型和大小,默认’uint8=>double’
常见有uint,uint8、uint16等数据格式,需要根据源数据来确定;确定了数据格式后,fread自动根据类型从二进制文件中读取不同字节,然后转化为10进制输出;
但是在python中对二进制文件进行解码时,f.read并不提供对应分数据格式帮助自动解码,需要根据一定的解码规则进行解码:通常的格式如下:
举例:
分别使用matlab与python读取二进制文件并转化为8进制与16进制;
matlab:
header = fread(fid,1,‘uint8’);
len = fread(fid,1,‘uint16’);
python:
header = f.read(1) # 8进制
dlen = f.read(1*2) # 16进制
struct.unpack('H', dlen)
解释:python中默认“utf-8“格式读取,读8个bits为一个8进制字节串;所以8进制时,只需要read一个字节串;但是16进制需要2个字节串,所以需要读取2个字节串作为一个16进制输出;