trunc
和int
函数为我尝试过的每个浮点类型输入返回相同的输出。
它们的不同之处在于int
也可用于将数字字符串转换为整数。
所以我有一个双重问题:
trunc
和int
给出不同的输出?trunc
将浮点型数转换为整数更好?int
和math.trunc
与str
和repr
有一些类似的关系。 int
代表一种类型的__int__
方法,并且如果找不到__trunc__
则回退到__int__
方法。 math.trunc
直接委托类型的__trunc__
方法,没有后备。与__str__
和__repr__
不同,它们总是为object
定义,int
和math.trunc
都可以提出开箱即用的错误。
对于我所知道的所有内置类型,__int__
和__trunc__
都是合理定义的。但是,您可以定义自己的一组测试类,以查看您获得的错误:
class A:
def __int__(self):
return 1
class B:
def __trunc__(self):
return 1
class C(): pass
math.trunc(A())
和math.trunc(C())
都将提升TypeError: type X doesn't define __trunc__ method
。 int(C())
将提高TypeError: int() argument must be a string, a bytes-like object or a number, not 'C'
。然而,int(A())
,int(B())
和math.trunc(B())
都将成功。
最后决定使用哪种方法是内涵之一。 trunc
本质上是一个类似于floor
的数学运算,而int
是一个通用的转换,并且在更多的情况下成功。
不要忘记operator.index
和__index__
方法。