У мене є 2D масив numpy. Деякі значення в цьому масиві є NaN
. Я хочу виконати певні операції, використовуючи цей масив. Наприклад, розглянемо масив:
[[ 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.]]
Я намагаюся взяти кожен рядок по одному, відсортувати його в зворотному порядку, щоб отримати з рядка максимум 3 значення та взяти їх середнє значення. Код, який я спробував:
# 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
Це не працює для рядків, що містять NaN
. Моє питання полягає в тому, чи є швидкий спосіб перетворити всі NaN
значення на нуль у двовимірному масиві numpy, щоб у мене не було проблем із сортуванням та іншими речами, які я намагаюся зробити.
each: map: return isNaN(value) ? 0 : value