我试图理解什么from_bytes()
事实上确实如此。
The 文档提到了这一点:
byteorder 参数确定用于表示整数的字节顺序。如果字节顺序为“big”,则最高有效字节位于字节数组的开头。如果字节顺序为“little”,则最高有效字节位于字节数组的末尾。要请求主机系统的本机字节顺序,请使用 sys.byteorder 作为字节顺序值。
但这并没有真正告诉我字节值是如何实际计算的。例如我有这组字节:
In [1]: byte = b'\xe6\x04\x00\x00'
In [2]: int.from_bytes(byte, 'little')
Out[2]: 1254
In [3]: int.from_bytes(byte, 'big')
Out[3]: 3859021824
In [4]:
I tried ord()
它返回这个:
In [4]: ord(b'\xe6')
Out[4]: 230
In [5]: ord(b'\x04')
Out[5]: 4
In [6]: ord(b'\x00')
Out[6]: 0
In [7]:
我也不明白怎么办1254
or 3859021824
由上述值计算得出。
我还发现这个问题但它似乎并没有准确解释它是如何工作的。
那么它是如何计算的呢?
大字节顺序就像通常的十进制表示法,但以 256 为基数:
230 * 256**3 + 4 * 256**2 + 0 * 256**1 + 0 * 256**0 = 3859021824
就像
1234 = 1 * 10**3 + 2 * 10**2 + 3 * 10**1 + 4 * 10**0
对于小字节顺序,顺序相反:
0 * 256**3 + 0 * 256**2 + 4 * 256**1 + 230 = 1254
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)