J'ai un tableau numpy 2D. Certaines des valeurs de ce tableau sont NaN
. Je souhaite effectuer certaines opérations à l'aide de ce tableau. Par exemple, considérons le tableau :
[[ 0. 43. 67. 0. 38.]
[ 100. 86. 96. 100. 94.]
[ 76. 79. 83. 89. 56.]
[ 88. NaN 67. 89. 81.]
[ 94. 79. 67. 89. 69.]
[ 88. 79. 58. 72. 63.]
[ 76. 79. 71. 67. 56.]
[ 71. 71. NaN 56. 100.]]
J'essaie de prendre chaque ligne, une à la fois, de la trier dans l'ordre inverse pour obtenir les 3 valeurs maximales de la ligne et de calculer leur moyenne. Le code que j'ai essayé est le suivant :
# nparr is a 2D numpy array
for entry in nparr:
sortedentry = sorted(entry, reverse=True)
highest_3_values = sortedentry[:3]
avg_highest_3 = float(sum(highest_3_values)) / 3
Cela ne fonctionne pas pour les lignes contenant NaN
. Ma question est la suivante : existe-t-il un moyen rapide de convertir tous les . NaN
à zéro dans le tableau numpy 2D afin que je n'aie pas de problèmes avec le tri et les autres choses que j'essaie de faire.