确定字节序的最Pythonic方法是什么?

Maj*_*jor 37 python endianness

我正在努力找到解决我的代码运行的机器是big-endian还是little-endian的最佳方法.我有一个有效的解决方案(虽然我没有在大端机器上测试它)但它看起来有点笨重:

import struct
little_endian = (struct.pack('@h', 1) == struct.pack('<h', 1))
Run Code Online (Sandbox Code Playgroud)

这只是将"本机"双字节包与little-endian包进行比较.有更漂亮的方式吗?

Sco*_*ths 84

答案在sys模块中:

>>> import sys
>>> sys.byteorder
'little'
Run Code Online (Sandbox Code Playgroud)

当然,根据您的机器,它可能会返回'big'.你的方法当然也应该有效.

  • 是的,在powerpc上它说`>>> sys.byteorder'big'` (4认同)