Python:无符号32位逐位算术

Fed*_*oni 31 python math

试图回答其解决方案涉及IP地址和网络掩码的另一篇文章,我陷入了简单的按位运算.

在Python中是否有一种标准方法可以进行按位AND,OR,XOR,NOT操作,假设输入为"32位"(可能为负)整数或长整数,并且结果必须在范围内为长[ 0,2**32]?

换句话说,我需要一个有效的Python对应于无符号长整数之间的C位运算.

编辑:具体问题是:

>>> m = 0xFFFFFF00   # netmask 255.255.255.0
>>> ~m
-4294967041L         # wtf?! I want 255
Run Code Online (Sandbox Code Playgroud)

Dzi*_*inX 52

你可以使用ctypes及其c_uint32:

>>> import ctypes
>>> m = 0xFFFFFF00
>>> ctypes.c_uint32(~m).value
255L
Run Code Online (Sandbox Code Playgroud)

所以我在这里做的是转换~m为C 32位无符号整数并以Python格式检索其值.


Joh*_*kin 42

你可以掩盖一切0xFFFFFFFF:

>>> m = 0xFFFFFF00
>>> allf = 0xFFFFFFFF
>>> ~m & allf
255L
Run Code Online (Sandbox Code Playgroud)


pix*_*eat 11

from numpy import uint32
Run Code Online (Sandbox Code Playgroud)

  • 为什么不携带? (3认同)

Maa*_*ten 6

您还可以与 0xFFFFFFFF 进行异或,这相当于“无符号补码”。

>>> 0xFFFFFF00 ^ 0xFFFFFFFF
255
Run Code Online (Sandbox Code Playgroud)