Tutoriels > Tutoriels & Astuces Excel > Fonctions & Formules > Nommer une Plage Dynamique

Nommer une Plage Dynamique

Publié par Mth le 06-12-2008 (100792 lectures)

Nommer une Plage Dynamique

Selon les cas, la taille d'une plage n'est pas forcément connue à l'avance, et est susceptible d'évoluer.

 

La taille des plages nommées peut être ainsi variable et nous allons voir comment gérer ce type de références.

 

 

 

 

Pour illustrer cette situation, prenons un exemple :

 

Les ouvrages d'une collection se répartissent sur plusieurs gammes de A à D, chaque gamme correspond à un prix, indiqué dans le tableau Tarif.

Plage dynamique 1



Dans le tableau Chiffre d'Affaires, nous voulons calculer le CA généré par chaque ouvrage, en fonction de son prix indiqué dans le tableau Tarif

 

Plage dynamique 3

 

Pour les calculs du CA, nous avons donc besoin de nommer les plages :

  • Gamme (actuellement de C19 à C22)
  • Prix_Tarif (actuellement de D19 à D22) 

 Plage dynamique 2

 

Cependant, nous savons que le tarif va s'enrichir d'autres gammes, mais nous ne savons pas dans quelles proportions.

Nommer directement les plages Gamme sur C19:C22 et Prix_Tarif sur D19:D22 n'est donc pas une solution idéale. 

 

Dans le doute, nous pouvons décider d'étendre les plages jusqu'aux lignes 25, ou 30 ou 40 pour laisser de la marge, mais cette solution n'est pas très élégante ni optimisée.

 

Pour faire en sorte que nos plages soient « dynamiques », c'est à dire tiennent compte automatiquement du nombre de lignes ou colonnes renseignées, nous allons utiliser deux fonctions : la fonction NBVAL() et la fonction DECALER().

 

 

La fonction NBVAL() va permettre de compter le nombre de cellules non vides

 

La formule =NBVAL($C:$C) renvoie 5

En effet il y a bien 5 cellules non vides dans cette colonne, entête de colonne comprise, de C18 à C22 pour l'instant.

 

 

La fonction DECALER() va permettre de déterminer la plage

 

Syntaxe de cette fonction :

DECALER( Réf; Nombre de lignes; Nombre de colonnes; Hauteur; Largeur

 

 Réf

Cellule de départ à partir de laquelle le décalage doit être opéré.

Ici, nous partons de la cellule $C$19 pour déterminer la plage Gamme

 Nombre de lignes

Nombre de lignes vers le haut (chiffre négatif) ou vers le bas (chiffre positif) dont la cellule supérieure gauche de la référence renvoyée doit être décalée.

Ici, nous n'avons pas besoin de ce décalage, cet argument restera donc à zéro

 Nombre de colonnes

Idem que pour les lignes.

Ici, nous n'avons pas besoin de ce décalage, cet argument restera donc à zéro.

 Hauteur Indique la hauteur de la plage, en nombre de lignes (elle doit être impérativement supérieure à 0).
Nous savons grâce à NBVAL() combien nous avons de lignes renseignées. Hauteur sera donc égale au résultat de NBVAL() -1 compte tenu du titre de la colonne du tableau.
 Largeur

Indique la largeur de la plage, en nombre de colonnes (la largeur doit également être supérieure à 0).

Ici, nous travaillons sur un seule colonne, la Largeur sera donc égale à 1


La plage nommée « Gamme » fera donc référence à :
Formule Excel :

=DECALER($C$19;;;NBVAL($C:$C)-1;1)

Tandis que la plage nommée « Prix_Tarif » fera référence à :
Formule Excel :

=DECALER($D$19;;;NBVAL($D:$D)-1;1)

Notez toutefois que le nom de l'onglet sera ajouté à la vraie fonction.

 

Plage dynamique 4

 

Pour tester, dans notre tableau Tarif nous pouvons rentrer juste sur la ligne du dessous une gamme E et une gamme F, respectivement à 6 € et 7 €, puis éventuellement, saisir d'autres données dans le tableau Chiffre d'affaires.

 

La formule du tableau Chiffre d'Affaires fonctionnera avec les plages qui seront automatiquement adaptées !

 

 

 Attention !

ATTENTION!

  • Il ne faut pas de cellules vides dans les colonnes C ou D du tableau Tarif pour que la fonction présentée ici soit juste.
  • Il ne faut pas omettre les signes $ dans la formule des plages nommées.

 

 

Auteur de cet article : Mth

Retrouvez le dossier complet comprenant ces 3 articles :
 
 
 ...dans un classeur disponible en téléchargement : Références aux cellules ou plages .

 

Pour toutes vos questions ou si vous rencontrez des difficultés, n'hésitez pas à rejoindre nos Forums de Discussions !

Tags Tutoriel   Fonction   Formule   Dynamique   Plage   DECALER()   NBVAL()   Nommer  

 

Autres articles dans cette catégorie Publié le Vues
Rechercher une Fonction 28-05-2013 10488
T() - Tester et renvoyer du texte 02-07-2012 31216
EPURAGE() - Supprimer certains caractères indésirables 02-06-2012 86651
REMPLACER() - Echanger une chaîne de caractères par une autre 02-06-2012 30400
CTXT() - Convertir un nombre en texte 23-05-2012 84716
REPT() - Répéter des caractères un certain nombre de fois 26-04-2012 41885
L'Assistant Somme Conditionnelle 01-11-2011 17044
CELLULE() - Nom de l'onglet, du fichier ou du répertoire dans une cellule 03-10-2010 160809
EXACT() - Comparer deux chaînes de texte 26-04-2010 171271
Purgez les espaces inutiles ! 05-04-2010 210704
SUPPRESPACE() - Supprimer les espaces inutiles dans une cellule 05-04-2010 109307
STXT() - Extraire une chaîne de caractères au sein d'une autre 13-03-2010 398182
CHERCHE() TROUVE() - Retourne la position d'une chaîne de caractères 04-01-2010 187085
NBCAR() - Compter les caractères d'une chaîne de texte ou d'une plage de cellules 21-11-2009 46185
SUBSTITUE() - Remplacer une chaîne de texte par une autre 08-11-2009 210625
CAR() - CODE() : Utilisation des codes caractères 25-10-2009 77858
CONCATENER() - Assembler plusieurs chaînes de texte en une seule. 10-10-2009 44945
TEXTE() - Convertir une valeur numérique en texte formaté 29-09-2009 139960
DROITE() - GAUCHE() : Extraire les premiers ou derniers caractères d'une chaîne. 12-09-2009 488051
MAJUSCULE() - MINUSCULE() - NOMPROPRE(): Modifier la casse d'un texte 23-08-2009 13743
CNUM() - Convertir une chaîne en valeur numérique 19-08-2009 103487
DATEDIF() : Calculer la différence entre deux dates 26-07-2009 367056
Nommer une Plage Dynamique 06-12-2008 100793
Nommer une Plage de Cellules 05-12-2008 104623
Références Relatives & Absolues 05-12-2008 24599
Formule pour Nombres Premiers 29-08-2007 27343