Excel, somme automatiques conditionnelles

Résolu
kaz -  
 sopat34 -
Bonjour,

j'ai un petit soucis dans excel, je souhaite faire un comparatif de sommes cumulées sur plusieurs lignes mais avec des valeurs non encore renseignées.
ex : j'ai des valeurs mensuelles pour 2004 et je rentre celles de 2005 et j'aimerai qu'une cellule me calcule uniquement le cumul 2004 sur les memes mois remplis en 2005. En clair, j'ai saisi des valeurs de janvier à mars 2005 et je cherche la formule pour qu'automatiquement le cumul de janvier à mars 2004 s'affiche.

Merci de votre aide

Cordialement,

Kaz
A voir également:

14 réponses

gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
bonjour

peux-tu préciser un peu la question.

tu as de nombreuses lignes 2004 et 2005
et en haut ou en bas de ton tableau tu as une ligne cumul
avec par exemple : =somme.si(plage;cellule=2004)
et idem pour 2005 sur une autre ligne ?

2
gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
bonjour

tu peux tout aussi bien ne fonctionner qu'avec excel.

la cellule qui te donne rappel période 2004 prend la formule :

=SOMME(SI(plage_2005="";0;plage_2004))

en validant avec CTRL + MAJ + ENTREE pour travailler en matriciel
avec 'plage_2005' : tes données complétes 2005
et ''plage_2004' : tes données complétes 2004.

On oublies souvent la puissance des formules matricielles !

bon courage.

1
Armojax Messages postés 1860 Date d'inscription   Statut Membre Dernière intervention   1 528
 
Hello gb,

Beaucoup mieux !!!
Je suis passé complètement à côté.

Pourquoi faire simple quand...
Armojax.
0
obélix
 
bonsoir
comment je peut retirer une somme tout les mois a la meme date sous exel
1
kaz
 
gbinforme,

j'ai un cumul pour 2005 dans une seule cellule et j'aimerai que dans une seule cellule à côté apparaisse le cumul pour 2004 concernant les mois saisis. Cette cellule se mettant à jour chaque mois sans conserver d'historique et dans un soucis d'avoir un tableau épuré.

Ex Février 2005

Janv Fév Mars ...Déc Tot
2004 50 124 130 380 1980 rappel période 2004
2005 120 190 vide... vide 310 174

Ex Mars 2005

Janv Fév Mars ...Déc Tot
2004 50 124 130 380 1980 rappel période 2004
2005 120 190 224... vide 534 304




J'espère que ces précisions t'auront éclairer.

Merci

Kaz
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Armojax Messages postés 1860 Date d'inscription   Statut Membre Dernière intervention   1 528
 
Bonjour Kaz,

La petite macro ci-dessous, à mettre dans le code de ta feuille, devrait faire ce que tu veux.
J'ai appelé "EnCours" la plage des 12 cellules des valeurs mensuelles de 2005, et "Partiel" la cellule qui reçoit le cumul partiel de l'année précédente.
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

  Dim Lig     As Integer
  Dim Col     As Integer
  Dim Tot     As Double

  Lig = Range("EnCours").Row
  Col = Range("EnCours").Column
  Tot = 0

  Do While Cells(Lig, Col).Value <> ""
    Tot = Tot + Cells(Lig - 1, Col).Value
    Col = Col + 1
  Loop
  
  Range("Partiel").Value = Tot

End Sub
Armojax.
0
kaz
 
Merci Armojax, ton code marche nickel.

Par contre est-ce qu'il est possible de modifier le code afin de faire le calcul des cumuls sur plusieurs tableaux de meme forme.

De ce fait, il y aurait plusieurs cellules "partiel" qui se référent a à une plage propre "en cours" mais située au même endroit (L-1; C-13:L-1; C-2) par rapport à chaque cellule.

A+

Kaz
0
Armojax Messages postés 1860 Date d'inscription   Statut Membre Dernière intervention   1 528
 
Re kaz,

J'ai supposé que tu as un nombre indéterminé de structures identiques, dans une même feuille.
La nouvelle macro n'utilise plus les noms de plages de cellules.
Pour la paramétrer, il faut que tu indiques, dans les tableaux Array de la macro, les coordonnées de chaque cellule "Janvier" de l'année en cours.

Par exemple, si tu as 3 structures dans ta feuille, donc 3 lignes "Année 2005", dont les cellules "Janvier" se trouvent en : A2, C13, F21, tu dois écrire :
Lignes = Array(2, 13, 21)
Colonnes = Array(1, 3, 6)
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

  Dim I         As Integer
  Dim Lig       As Integer
  Dim Col       As Integer
  Dim Der       As Integer
  Dim Tot       As Double
  Dim Lignes    As Variant
  Dim Colonnes  As Variant
  
  Lignes = Array(3, 13)   ' placer ici les n° des lignes année en cours
  Colonnes = Array(2, 7)  ' n° de colonnes de "janvier" année en cours
  
  With Application.WorksheetFunction
    For I = 0 To UBound(Lignes)
      Lig = Lignes(I)
      Col = Colonnes(I)
      Der = .Min(Me.Cells(Lig, Col).Offset(0, -1).End(xlToRight).Column, Col + 11)
      Tot = .Sum(Range(Cells(Lig - 1, Col), (Cells(Lig - 1, Der))))
      Me.Cells(Lig, Col).Offset(0, 13).Value = Tot
    Next I
  End With
  
End Sub
0
kaz
 
J'ai bien compris ton code mais je n'arrive pas à l'adapter dans mon tableau. J'ai plusieurs lignes pour l'array mais qu'une seule colonne et en lançant la macro il m'indique une erreur de compilation.

En effet, pour ne rien compliquer je n'ai qu'une ligne avec les mois et tous mes tableaux sont accolés. Concrêtement, j'ai mon janvier que en C6, février en C7 etc, mes 1eres donnees 2004 sont de C9 à N9 et 2005 de C10 à N10, mes 2e données 2004 de C18 à N18 et 2005 de C19 à N19 et les dernières de C28 à N28 et 2005 de C29 à N29.
Les cellules partielles sont en Q10, Q19 et Q29.

Merci de ton aide et bon week, je ne pourrai pas me connecter avant

Kaz
0
kaz
 
Merci à vous deux,

ça marche impec gb, je dormirai moins C.. ce soir

Kaz
0
soflouna
 
Bjr,

je souhaite faire la somme de de cellule comme suite: a12;c12;e12;g12........

par une simple formule

merci d'avance
0
gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
bonjour

Pour cumuler toutes les cellules numériques de la ligne 12 tu peux mettre :
=SOMME(A12:IV12)
0
gbinforme Messages postés 14946 Date d'inscription   Statut Contributeur Dernière intervention   4 724
 
bonjour

Pour retirer une somme tous les mois à la même date vas au distributeur c'est plus simple.
0
jean pierre francois
 
Bonjour et Vive la France!!!!!!!Je suis un grand utilisateur Merci Paris Hiérarchisation et Sommaire automatique dildo. Merci Bocoup!
0
sopat34
 
Il est supposé exister une formule somme(si(1er critère)*(2eme critère);plage ou se fait la somme)
voici ma formule :
=SI(J5<>"";SOMME(SI((B$3:B$4000=B5)*(G$3:G$4000=G5);H$3:H$4000));"")
si j5 est vide, je passe, sinon je recherche les occurrences de b5 dans la plage b3:b4000. parmi ces occurrences, je recherches celles dont g5 existe et je fais la somme de la colonne H pour celles-ci.
9a a fonctionné, mais tout à coup, ça m'a mis la somme totale H3:H4000 je ne sais pas pourquoi, je n'ai rien changé à la formule.
mais cette formule est décrite dans l'aide d'Excel 2003.
0
sopat34
 
Il est supposé exister une formule somme(si(1er critère)*(2eme critère);plage ou se fait la somme)
voici ma formule :
=SI(J5<>"";SOMME(SI((B$3:B$4000=B5)*(G$3:G$4000=G5);H$3:H$4000));"")
si j5 est vide, je passe, sinon je recherche les occurrences de b5 dans la plage b3:b4000. parmi ces occurrences, je recherches celles dont g5 existe et je fais la somme de la colonne H pour celles-ci.
9a a fonctionné, mais tout à coup, ça m'a mis la somme totale H3:H4000 je ne sais pas pourquoi, je n'ai rien changé à la formule.
mais cette formule est décrite dans l'aide d'Excel 2003.
0