Utilisez val.item()
pour convertir la plupart des valeurs NumPy en un type Python natif:
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'>
...
(Une autre méthode est np.asscalar(val)
, cependant, elle est obsolète depuis NumPy 1.16).
Pour les curieux, pour construire une table de conversions de scalaires de tableau NumPy pour votre système:
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
Il y a quelques types numpy sans équivalent Python natif sur certains systèmes, y compris: clongdouble
, clongfloat
, complex192
, complex256
, float128
, longcomplex
, longdouble
et longfloat
. Ceux-ci doivent être convertis en leur équivalent NumPy le plus proche avant utilisation .item()
.