Verwenden Sie val.item()
diese Option, um die meisten NumPy-Werte in einen nativen Python-Typ zu konvertieren:
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'>
...
(Eine andere Methode ist np.asscalar(val)
jedoch seit NumPy 1.16 veraltet).
Für Neugierige, um eine Tabelle mit Konvertierungen von NumPy-Array-Skalaren für Ihr System zu erstellen :
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
Es gibt ein paar NumPy Typen , die keine native Python Äquivalent auf einigen Systemen, einschließlich: clongdouble
, clongfloat
, complex192
, complex256
, float128
, longcomplex
, longdouble
und longfloat
. Diese müssen vor der Verwendung in das nächste NumPy-Äquivalent konvertiert werden .item()
.