问题
当面对未知长度的带符号十六进制数字时,如何使用Excel公式轻松地将这些十六进制数字转换为十进制数字?
示例
Hex
---
00
FF
FE
FD
0A
0B
答案 0 :(得分:2)
使用此深层嵌套的formula:
=HEX2DEC(N)-IF(ISERR(FIND(LEFT(IF(ISEVEN(LEN(N)),N,CONCAT(0,N))),"01234567")),16^LEN(IF(ISEVEN(LEN(N)),N,CONCAT(0,N))),0)
其中N
是包含十六进制数据的单元格。
展开时,此公式变得更具可读性:
=HEX2DEC(N) -
/* check if sign bit is present in leftmost nibble, padding to an even number of digits if necessary */
IF( ISERR( FIND( LEFT( IF( ISEVEN(LEN(N))
, N
, CONCAT(0,N)
)
)
, "01234567"
)
)
/* offset if sign bit is present */
, 16^LEN( IF( ISEVEN(LEN(N))
, N
, CONCAT(0,N)
)
)
/* do not offset if sign bit is absent */
, 0
)
可能被理解为“首先,将十六进制值转换为无符号十进制值。然后,如果数据的最左边半字节包含符号位,则偏移无符号十进制值;否则不要偏移。”
示例转换
Hex | Dec
-----|----
00 | 0
FF | -1
FE | -2
FD | -3
0A | 10
0B | 11
答案 1 :(得分:0)
让A1
单元格包含一个大小写为1字节的十六进制字符串。
要获取此字符串的2的补码十进制值,请使用以下命令:
=HEX2DEC(A1)-IF(HEX2DEC(A1) > 127, 256, 0)
对于任意长度的字节,请使用以下内容:
=HEX2DEC(A1) - IF(HEX2DEC(A1) > POWER(2, 4*LEN(A1))/2 - 1, POWER(2, 4*LEN(A1)), 0)