在我的程序中,我正在查看一个字符串,我想知道它是否代表一个 32 位整数。
目前我首先检查它是否是一个数字isdigit(),然后我检查它是否超过 2^32 的值(假设我不关心无符号值)。
检查我的输入字符串是否包含有效的 32 位整数的最佳方法是什么?
换个思路,看看值是否可以打包成 4 个字节:
>>> from struct import pack, error
>>> def test_32bit(n):
...     try:
...             pack("i", n)
...     except error:
...             return False
...     return True
... 
如果使用无符号值,pack("I", n)则改为。
对于无符号值,这将起作用:
>>> def is32(n):
...     try:
...         bitstring=bin(n)
...     except (TypeError, ValueError):
...         return False
...         
...     if len(bin(n)[2:]) <=32:
...         return True
...     else:
...         return False    
... 
>>> is32(2**32)
False
>>> is32(2**32-1)
True
>>> is32('abc')
False
    >>> def is_int32(number):
...     try:
...         return not(int(number)>>32)
...     except ValueError:
...         return False
    简单的解决方案将是这样的
if abs(number) < 2**31 and number != 2**31 - 1:
   return True
else:
   return False
如果我们的号码在[−2^31,  2^31 − 1]范围内,我们很高兴
>>> def is_32_bit(n: int) -> bool:
...     if n in range(-2 ** 31, (2**31) - 1):
...         return True
...     return False
... 
>>> is_32_bit(9999999999)
False
>>> is_32_bit(1)
True
    我们可以使用左移运算符来应用检查。
def check_32_bit(n):
    return n<1<<31