博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python解析二进制文件以及不同进制数值间的转换
阅读量:4158 次
发布时间:2019-05-25

本文共 1043 字,大约阅读时间需要 3 分钟。

目录

1、python解析二进制文件

不同类型数据的字节数不同,因此首先要明确不同物理量数据所在的字节位置及其数据类型,python和C语言中不同数据类型对应关系如下,表中standard size一列给出了该类型数据占据的字节个数。

在这里插入图片描述
用python解析二进制文件的代码示例如下,这里需要注意的是:

  • (1)明确你想解析出来的数据所在的字节范围;
  • (2)明确该数据的数据类型,以避免解析结果错误或字节数不匹配。
binFile=open('./DeviceBuffer_04151401\\00000004_00000618.ds','rb')binFile.seek(9) #先定位到第9个字节,然后再读出其后面的4个字节:10,11,12,13context=binFile.read(4) #读取第9个字节后面的四个字节realContext=struct.unpack('i',context) #利用struct.unpack将对应类型数据解析出来,'i'表示这四个字节对应的数据是int类型,正好与上一行读取的四个字节数对应print(realContext)

2、不同进制数值间的转换

有时候需要对struct.unpack解析出来的结果进一步处理,例如数据存储时,如果将两个16位的二进制的物理量组合成一个32位二进制数据再进行存储,那就需要将struct.unpack解析出来的结果先转为二进制格式,然后再将高16位和低16位分开,分别转化为对应的十进制物理量

以上叙述对应的代码如下:

print('电压:%s'%int(bin(realContext)[0:-16],2),' '*5,	'电流:%s'%int('0b'+bin(realContext)[-16:],2))

python中进行不同进制转换的函数如下表所示:

在这里插入图片描述
注意:bin(),oct()和hex()输出的结果是str类型,且开头分别以’0b’,'0o’和’0x’标记,例如一个二进制数为:

‘0b110100110100000011111101101’

注意,bin(int(x,10))中的x是str类型,而bin(x)中的x是int类型。

参考文献:

[1] https://blog.csdn.net/lovelyaiq/article/details/81988185

[2] https://blog.csdn.net/xdreamman/article/details/93497535

你可能感兴趣的文章
Javascript 的MVC模式(一)
查看>>
IOS6 中新特性介绍
查看>>
oracle客户端 100%安装成功步骤
查看>>
从客户端中检测到有潜在危险的 Request.Form 值
查看>>
quickSort - 编程细节
查看>>
CUDA数组分配
查看>>
线性代数 - 06 二次型
查看>>
【学习】js学习笔记:数组(二)
查看>>
心得——学习中做笔记应该做到哪
查看>>
[转]Linux联网问题
查看>>
Linq高级查询与分页查询
查看>>
设置Mysql登陆默认编码
查看>>
启动tomcat报错 java.lang.Exception: Socket bind failed
查看>>
SploitFun Linux x86 Exploit 开发系列教程
查看>>
linux mint 崩溃
查看>>
java课堂 笔记
查看>>
JAVA
查看>>
不要忽略ShareMem, 否则异常将伴
查看>>
带权无向图的最小生成树的构造
查看>>
神奇的CSS3选择器
查看>>