我有一个Python函数,它接受一个必须是整数的数字参数,以使其行为正确.在Python中验证这个的首选方法是什么?
我的第一反应是做这样的事情:
def isInteger(n): return int(n) == n
但我不禁想到这是1)昂贵的2)丑陋和3)受到机器epsilon的温柔怜悯.
Python是否提供任何本地的类型检查变量方法?或者这被认为是违反语言的动态类型设计?
编辑:因为有很多人问过 - 有问题的应用程序使用IPv4前缀,从平面文本文件中获取数据.如果任何输入被解析为浮点数,则该记录应被视为格式错误并被忽略.
isinstance(n, int)
如果你需要知道它是否是一个真正的int而不是int的子类(通常你不需要这样做):
type(n) is int
这个:
return int(n) == n
这不是一个好主意,因为跨类型的比较可能是真的 - 特别是 int(3.0)==3.0
是的,正如埃文所说,不要打字检查.只是尝试使用该值:
def myintfunction(value): """ Please pass an integer """ return 2 + value
那没有一个类型检查.它好多了!让我们看看尝试时会发生什么:
>>> myintfunction(5) 7
这是有效的,因为它是一个整数.嗯.让我们尝试一些文字.
>>> myintfunction('text') Traceback (most recent call last): File "", line 1, in File " ", line 3, in myintfunction TypeError: unsupported operand type(s) for +: 'int' and 'str'
它显示了一个错误TypeError,它应该是它应该做的.如果来电者想要抓住这个,那就有可能.
如果做了一次类型检查,你会怎么做?显示错误对吗?因此,您不必进行类型检查,因为错误已经自动显示.
此外,由于您没有进行类型检查,因此您可以使用其他类型的功能:
湘江边:
>>> print myintfunction(2.2) 4.2
复数:
>>> print myintfunction(5j) (2+5j)
小数点:
>>> import decimal >>> myintfunction(decimal.Decimal('15')) Decimal("17")
甚至可以添加数字的完全随意的对象!
>>> class MyAdderClass(object): ... def __radd__(self, value): ... print 'got some value: ', value ... return 25 ... >>> m = MyAdderClass() >>> print myintfunction(m) got some value: 2 25
因此,你很明显没有得到什么.并且失去了很多.
由于您已经编辑了这个问题,现在很清楚,您的应用程序调用了一些上行例程,只有整数才有意义.
既然如此,我仍然认为你应该将接收到的参数传递给上游函数.上游函数将正确处理它,例如在需要时引发错误.我非常怀疑,如果你传递一个浮点数,你处理IP的函数会表现得很奇怪.如果您可以给我们图书馆的名称,我们可以为您检查.
但是......如果上游函数表现不正确并且杀了一些孩子,如果你传递一个浮点数(我仍然高度怀疑它),那么只需调用int()
它:
def myintfunction(value): """ Please pass an integer """ return upstreamfunction(int(value))
你仍然没有进行类型测试,所以你获得的不是类型测试的好处.
即使在所有这些之后,你真的想要输入检查,尽管它会降低你的应用程序的可读性和性能而绝对没有任何好处,但是使用assert
它来做.
assert isinstance(...) assert type() is xxxx
这样我们可以通过调用它来关闭assert
s并从程序中删除此
功能
python -OO program.py