답변:
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
정수를 int와 같은 정수로 안전하게 변환하는 가장 간단한 방법 8
은 np.rint(arr).astype(int)
무엇입니까?
astype(np.uint8)
당신은 확실히 당신의 입력이 NumPy와 배열을 될 것입니다하지 않는 경우, 당신은 사용할 수 있습니다 asarray
로 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)
outputsarray([-9223372036854775808])
입니다.