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, longdoubleet longfloat. Ceux-ci doivent être convertis en leur équivalent NumPy le plus proche avant utilisation .item().