Moyenne sur les 30 dernières lignes

Résolu
Magnum812 Messages postés 6 Statut Membre -  
Magnum812 Messages postés 6 Statut Membre -
Bonjour,

Je vais essayer d'expliquer clairement mon besoin (Excel 2007).
J'ai un tableau excel à plusieurs colonnes et dont une nouvelle ligne est créée chaque jour. La deuxième ligne de chaque colonne (la première ligne étant celle des libellés) calcule la moyenne générale des données non vide des cellules en dessous [ex: en C2: =MOYENNE(C4:C65000) Par exemple] Jusque là pas de soucis.
Par contre dans la deuxième ligne du tableau j'aimerai qu'il calcule la moyenne des 30 derniers jours (donc les 30 dernières lignes non vide en dessous)
Exemple: Aujourd'hui on rempli la ligne 60, il doit calculer la moyenne de la ligne 60 à la ligne 31 - Demain on rempli la ligne 61, il doit calculer la moyenne de la ligne 61 à la ligne 32... Etc...
J'espère avoir été suffisamment clair...
Merci pour votre aide

3 réponses

ccm81 Messages postés 11033 Statut Membre 2 433
 
Bonjour à tous

Un peu tard, mais non ...
Dans mon tableau il y a certaines cellules vide, donc la fonction NBVAL compte les cellules non vide et ne fait pas la moyenne sur les bons chiffres
Peut être avec une fonction personnalisée (macro)
http://www.cjoint.com/c/GIjjvglgwVB

Cdlmnt
1
mdo100 Messages postés 126 Date d'inscription   Statut Membre Dernière intervention   22
 
Bonjour ccm81,

Bien vu la fonction personnalisée (Que je ne sais pas faire), et que j'ai bien noté.
Mais elle ne traite pas les valeurs alphabétiques, ce que je veux dire, si par exemple il y a un mot quelconque dans la colonne "A" entre les 10 où 20 dernières valeurs numérique, alors la fonction ne marche plus.

Comment ferais-tu pour remédier a ce problème ?

Cordialement.
0
ccm81 Messages postés 11033 Statut Membre 2 433
 
Tu complètes la ligne
While n < nd
  If Range(co & li).Value <> "" And IsNumeric(Range(co & li).Value) Then


Cdlmnt
0
mdo100 Messages postés 126 Date d'inscription   Statut Membre Dernière intervention   22 > ccm81 Messages postés 11033 Statut Membre
 
Re ccm81,

Génial, cela évite donc d'utiliser une formule matricielle gourmande en ressource.

Merci de ta réponse, qui me servira sans aucun doute et qui devrait aussi répondre à Magnum812.

Cordialement.
0
Magnum812 Messages postés 6 Statut Membre > mdo100 Messages postés 126 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour à tous,

Après plusieurs essais différents, certains concluent, d'autres moins je vais peaufiner tout ça et l'adapter à mon tableau...
J'hésite encore entre une macro ou une formule matricielle...
En tout cas la solution a mon problème se trouve dans vos réponses et je vous en remercie tous.
Par contre je ne sais pas comment mettre ce sujet en résolu !!

Bonne semaine à tous,
Cordialement,
0
pijaku Messages postés 13513 Statut Modérateur 2 763
 
Bonjour,

Il doit certainement y avoir plus simple et plus élégant, mais cette formule fonctionne :
=MOYENNE(DECALER(C4;NBVAL(C4:C65000)-30;0;;):DECALER(C4;NBVAL(C4:C65000);0;;))

0
Vaucluse Messages postés 27336 Statut Contributeur 6 441
 
Bonjour (et salut pijaku)

pour faire un tout petit peu plus simple, je crois du moins)

=MOYENNE(DECALER(C4;NB.VAL(C4;C65000)-30;;30))

crdlmnt
0
Magnum812 Messages postés 6 Statut Membre > Vaucluse Messages postés 27336 Statut Contributeur
 
Bonjour pijaku et Vaucluse

Ah ben dis donc c'est du rapide...
Je vais essayer ça tout à l'heure et je vous tiens au courant.
En tout cas merci à vous deux...

A plus...
0
pijaku Messages postés 13513 Statut Modérateur 2 763 > Vaucluse Messages postés 27336 Statut Contributeur
 
Salut Vaucluse,

+1

Mais...
Comme ceci, ça passe mieux :
=MOYENNE(DECALER(C4;NBVAL(C4:C65000)-30;;30;))
0
Vaucluse Messages postés 27336 Statut Contributeur 6 441 > pijaku Messages postés 13513 Statut Modérateur
 
Vi... je ne peux pas renier ma spécialité, les fautes de frappe (pour les deux points mais je crois que le dernier pont virgule n'est pas indispensable)
merci pour la correction
Bien cordialement
0
Magnum812 Messages postés 6 Statut Membre > pijaku Messages postés 13513 Statut Modérateur
 
Re-

J'ai un souci avec la formule, pour simplifier j'ai fait un essai sur 10 lignes donc :
Avec la formule = MOYENNE(J72:J81) pour un total de 379 j'obtiens bien 37,90 de moyenne.
Avec la formule =MOYENNE(DECALER(J4;NBVAL(J4:J65000)-10;;10;)) j'obtiens 38,40 de moyenne et la dernière cellule non vide est bien la J81 ! Je suis perdu !
J'ai fait des essais sur d'autres colonnes il y a toujours une différence ! (par contre je ne peux pas vous donner mon tableau pour vérifier)

Et sinon deuxième souci, quand il y a des cellules intermédiaires vide peut on faire une moyenne sur les 10 (ou 30) dernières cellules non vide du tableau ?
Par contre dans mon exemple ci-dessus il n'y a pas de cellules vide dans cette portion du tableau pour l'essai.

En tout cas merci à vous 2 d'essayer de m'aider, je continue à chercher de mon côté.

Bien cordialement...
0
mdo100 Messages postés 126 Date d'inscription   Statut Membre Dernière intervention   22
 
Bonjour toutes et tous,

Un essai en colonne "A":
=MOYENNE(SI(LIGNE(A:A)>=GRANDE.VALEUR(SI(ESTNUM(A:A);LIGNE(A:A));30);SI(ESTNUM(A:A);A:A)))

Formule matricielle a valider avec ctrl + maj +entrée

Cordialement.
0
Magnum812 Messages postés 6 Statut Membre
 
Bonjour mdo100,

Désolé pour la réponse tardive, je vais essayer ça (au plus tard lundi) et je te tiens au courant.
Un grand merci pour ton aide.

Bon weekend,
Cordialement...
0