Utilizzare val.item()
per convertire la maggior parte dei valori NumPy in un tipo Python nativo:
import numpy as np
# for example, numpy.float32 -> python float
val = np.float32(0)
pyval = val.item()
print(type(pyval)) # <class 'float'>
# and similar...
type(np.float64(0).item()) # <class 'float'>
type(np.uint32(0).item()) # <class 'long'>
type(np.int16(0).item()) # <class 'int'>
type(np.cfloat(0).item()) # <class 'complex'>
type(np.datetime64(0, 'D').item()) # <class 'datetime.date'>
type(np.datetime64('2001-01-01 00:00:00').item()) # <class 'datetime.datetime'>
type(np.timedelta64(0, 'D').item()) # <class 'datetime.timedelta'>
...
(Un altro metodo è np.asscalar(val)
, tuttavia è deprecato da NumPy 1.16).
Per i curiosi, per creare una tabella di conversioni di scalari di array NumPy per il tuo sistema:
for name in dir(np):
obj = getattr(np, name)
if hasattr(obj, 'dtype'):
try:
if 'time' in name:
npn = obj(0, 'D')
else:
npn = obj(0)
nat = npn.item()
print('{0} ({1!r}) -> {2}'.format(name, npn.dtype.char, type(nat)))
except:
pass
Ci sono alcuni tipi NumPy che non hanno nativa Python equivalente su alcuni sistemi, tra cui: clongdouble
, clongfloat
, complex192
, complex256
, float128
, longcomplex
, longdouble
e longfloat
. Questi devono essere convertiti nell'equivalente NumPy più vicino prima dell'uso .item()
.