我想要将从寄存器中读取来的字节数据拼接成十六位的整形,然后打印出来。但是想要把每次读取出来的无符号单字节数据拼成十六位的整形遇到了困难。 最开始的思路是使用位运算,对读出的数据进行移位操作,然后拼接在一起,最终赋值给一个变量。最终发现无论如何使用位运算进行操作,都无法获得一个十六位的有符号整形数据,因为 python 总是会用一个更大的数据结构来存放拼接后的数值,导致最终的打印结果永远是一个无符号的正数。最终发现想要解决这个问题,必须要使用 struct 模块。$ M; U5 J: Q4 D& ^ 使用这个模块进行数据拼接前,还要搞清楚数据的大小端问题,也就是先读出来的字节数据是高位还是低位问题,如果搞反了,最终得到的结果肯定是混乱的。大概率会看到各种莫名其妙的负数。 R+ m# ]6 ^3 n7 D* k$ G 话不多说,直接上代码了,一下代码实现了将两个字节合成一个十六位的有符号整形数据.5 B- x1 x7 r7 ?# K( Y buf=bytearray(2)& Z/ p- i. d& {( q* P! b/ W buf[0] = xyz[1]7 \ M) U7 \9 T/ l" q) H* P buf[1] = xyz[0] gyro_x = struct.unpack("<h", buf) / J) d, I7 s$ v* Z% W8 n 需要注意的是 buf[0] 和 buf[1] 里面存放的数据位置,也就是高低位要搞清楚,这样才能在后面 unpack 之后获得正确的数据。 下面附上各种数据的代号: 8 a5 w* z4 J! F; Z! d |* S - fmt:数据类型 - b — 字节型 - B — 无符号字节型 \) b" Y7 Y1 k# P, K% {+ ~ - h — 短整型 b7 h h4 A, Q* G - H — 无符号短整型1 u8 `4 Q! F0 w3 ?" r! R - i — 整型, \. D1 { p. }4 Q2 o5 H7 n h - I — 无符号整型 - l — 整型 - L — 无符号整型 - q — 长整型 - Q — 无符号长整型; a+ {; W3 {3 ^9 @8 j - f — 浮点型 - d — 双精度浮点型 - P — 无符号型 |