Risposte:
Usa il astype
metodo
>>> 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)
, e np.array([np.nan]).astype(int)
tutto restituire la stessa cosa. Perché?
nan
e inf
sono valori in virgola mobile e non possono essere convertiti in modo significativo in int. Come il commento prima delle tue note, ci sarà un comportamento sorprendente e non credo che il comportamento preciso sia ben definito. Se si desidera mappare nan
e inf
determinati valori, è necessario farlo da soli.
int
. Lo è numpy.int32
.
Alcune funzioni intorpidite su come controllare l'arrotondamento: rint , floor , trunc , ceil . a seconda di come si desidera arrotondare i float, su, giù o al più vicino int.
>>> 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.]])
Per rendere uno di questi in int, o uno degli altri tipi in numpy, astype (come ha risposto BrenBern):
a.astype(int)
array([[1, 2],
[1, 3]])
>>> y.astype(int)
array([[1, 2],
[1, 2]])
astype
è spesso troppo generico e penso che probabilmente sia più utile quando si eseguono conversioni intx - inty. Quando voglio fare la conversione float, int è la possibilità di scegliere il tipo di arrotondamento.
7.99999
a ints come 8
, è np.rint(arr).astype(int)
?
astype(np.uint8)
puoi usare np.int_
:
>>> x = np.array([[1.0, 2.3], [1.3, 2.9]])
>>> x
array([[ 1. , 2.3],
[ 1.3, 2.9]])
>>> np.int_(x)
array([[1, 2],
[1, 2]])
Se non sei sicuro che il tuo input sarà un array Numpy, puoi usare asarray
con dtype=int
invece di astype
:
>>> np.asarray([1,2,3,4], dtype=int)
array([1, 2, 3, 4])
Se l'array di input ha già il tipo corretto, asarray
evita la copia dell'array mentre astype
non lo fa (se non specificato 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
onp.nan
nel tuo array, poiché hanno risultati sorprendenti. Ad esempio,np.array([np.inf]).astype(int)
uscitearray([-9223372036854775808])
.