在我的程序中,我正在查看一个字符串,我想知道它是否代表一个 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