Veronica sait utiliser la fonction MOYENNE pour déterminer la moyenne d’une plage de valeurs. Elle aimerait cependant que la moyenne soit déterminée sur la base des valeurs non nulles de la plage.

Il existe plusieurs façons d’aborder ce problème. Le premier est de se rappeler comment une moyenne est calculée. Il est défini comme la somme d’une plage de valeurs divisée par le nombre d’éléments de la plage. Ainsi, vous pouvez calculer la moyenne d’exclusion en vous assurant simplement que le dénominateur (le nombre par lequel vous divisez) n’inclut aucune valeur nulle. Par exemple:

=SUM(A1:A50)/COUNTIF(A1:A50,"<>0")

Cette approche utilise la fonction NB.SI pour déterminer le nombre de cellules de la plage (A1: A50) qui ne contiennent pas zéro. Si cette plage contient non seulement des zéros, mais également des cellules vides et que vous ne voulez pas que les cellules vides figurent dans le résultat, vous devez utiliser une formule plus complexe:

=SUM(A1:A50)/(COUNTIF(A1:A50,"<>0")-COUNTBLANK(A1:A50)- (COUNTA(A1:A50)-COUNT(A1:A50)))

La fonction NB.SI compte les cellules qui n’évaluent pas explicitement à 0, mais elle compte les cellules vides et de texte. Le terme COUNTBLANK s’ajuste pour les cellules vides et la différence entre COUNTA et COUNT ajuste le nombre total pour les cellules qui contiennent du texte.

Bien sûr, vous pouvez également utiliser une formule matricielle pour faire votre calcul:

=AVERAGE(IF(A1:A50<>0,A1:A50))

N’oubliez pas que les formules matricielles doivent être entrées en utilisant la combinaison Ctrl + Maj + Entrée. Cette formule matricielle exclut également les espaces ou les cellules contenant du texte.

ExcelTips est votre source pour une formation Microsoft Excel rentable.

Cette astuce (7727) s’applique à Microsoft Excel 97, 2000, 2002 et 2003. Vous pouvez trouver une version de cette astuce pour l’interface ruban d’Excel (Excel 2007 et versions ultérieures) ici:

link: / excelribbon-An_Average_that_Excludes_Zero_Values ​​[Une moyenne qui exclut les valeurs nulles].