Answers:
使用astype
方法。
>>> x = np.array([[1.0, 2.3], [1.3, 2.9]])
>>> x
array([[ 1. , 2.3],
[ 1.3, 2.9]])
>>> x.astype(int)
array([[1, 2],
[1, 2]])
np.array([np.inf]).astype(int)
,np.array([-np.inf]).astype(int)
和np.array([np.nan]).astype(int)
所有返回同样的事情。为什么?
nan
和inf
是浮点值,无法有意义地转换为int。如您之前的评论所述,会有令人惊讶的行为,我认为确切的行为没有明确定义。如果要映射nan
并映射inf
到某些值,则需要自己执行。
int
。是numpy.int32
。
一些用于控制舍入的numpy函数:rint,floor,trunc,ceil。取决于您希望如何将浮点数向上,向下或最接近的整数取整。
>>> x = np.array([[1.0,2.3],[1.3,2.9]])
>>> x
array([[ 1. , 2.3],
[ 1.3, 2.9]])
>>> y = np.trunc(x)
>>> y
array([[ 1., 2.],
[ 1., 2.]])
>>> z = np.ceil(x)
>>> z
array([[ 1., 3.],
[ 2., 3.]])
>>> t = np.floor(x)
>>> t
array([[ 1., 2.],
[ 1., 2.]])
>>> a = np.rint(x)
>>> a
array([[ 1., 2.],
[ 1., 3.]])
要将其中之一转换为int或将numpy中的其他类型转换为astype(由BrenBern回答):
a.astype(int)
array([[1, 2],
[1, 3]])
>>> y.astype(int)
array([[1, 2],
[1, 2]])
astype
通常太通用了,我认为在进行intx-inty转换时,它可能更有用。当我想进行float-int转换时,可以选择舍入类型是一个不错的功能。
7.99999
,以整数喜欢8
,是np.rint(arr).astype(int)
?
astype(np.uint8)
如果不确定您的输入将是Numpy数组,则可以使用asarray
with dtype=int
代替astype
:
>>> np.asarray([1,2,3,4], dtype=int)
array([1, 2, 3, 4])
如果输入数组已经具有正确的dtype,请asarray
避免使用数组复制,astype
而不要这样做(除非您指定copy=False
):
>>> a = np.array([1,2,3,4])
>>> a is np.asarray(a) # no copy :)
True
>>> a is a.astype(int) # copy :(
False
>>> a is a.astype(int, copy=False) # no copy :)
True
np.inf
或np.nan
在您的阵列中,因为它们会产生令人惊讶的结果。例如,np.array([np.inf]).astype(int)
输出array([-9223372036854775808])
。