python-operator.ge的行为不一致

前端之家收集整理的这篇文章主要介绍了python-operator.ge的行为不一致 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

from operator import ge
import numpy as np

>>> ge([0,2,3],0.8)
True
>>> ge([0,np.float64(0.8))
array([False,True,True])

对行为差异有何解释?

后来发现:

>>> ge([0,np.float(0.8))
True

也:)

最佳答案
显然,Python和Numpy处理算术运算的方式之间存在差异. ge(a,b)与a> = b相同.如果一个操作数是一个Numpy对象,则将调用相应的方法,如果另一个操作数是一个数组,它将以元素方式进行比较.也就是说,如果执行以下操作,您将获得相同的结果:

In [3]: [0,3] >= np.float64(0.8)
Out[3]: array([False,True])

另一方面,Python在2和3版本中处理情况的方式有所不同.您大概正在使用Python-2.X,它具有相关的逻辑(几乎是逻辑上的笑),但是在python 3中,您不能比较不同类型的对象,除非为其中一个对象显式实现了相应的操作.对于除不同数值类型以外的内置对象,不同类型的对象永远不会比较相等.

In [4]:  ge([0,0.8)
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-4-405eded6881c> in <module>()
----> 1 ge([0,0.8)

TypeError: '>=' not supported between instances of 'list' and 'float'

阅读https://docs.python.org/3/library/stdtypes.html#comparisons了解更多详细信息.

原文链接:https://www.f2er.com/python/533144.html

猜你在找的Python相关文章