IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

faire une somme de valeurs avec la fonction SumIf


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 51
    Points : 34
    Points
    34
    Par défaut faire une somme de valeurs avec la fonction SumIf
    bonjour le forum ... j'ai besoin de votre aide

    j'ai deux colonnes B et D .. dans B j'ai des valeurs de types date et dans D des montants (type long)
    je veux faire la somme des valeurs de la colonne D qui correspondent à des dates entre le debut du mois précédant et sa fin (M-1)

  2. #2
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Bonjour,

    Sans VBA avec la formule Sommeprod

    Exemple : date en A et montant en B
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SOMMEPROD((A1:A86>=DATE(2011;2;1))*(A1:A86<=DATE(2011;2;28));B1:B86)
    Jérôme

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    merci .. quoique y a po moyen de le faire en VBA j'ai besoin d'affecter la somme a une variable et de faire un autre calcul deriere :S ...

  4. #4
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Pourquoi ne pas utiliser la formule, puis mettre son résultat dans la variable pour enfin supprimer la formule (Cellule temporaire)
    Jérôme

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    c'est s que je vais faire (c'est un peu limite parsque j'aurai 12 variable(autant de variable que de mois) ) pourtant avec la fonction ça marche toujours pas

    ça me fait un #div/0!

    j'ai fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =sommeprod((F2:F65536>=date(2011;6;1))*(F2:F65536<=DATE(2011;6;30));Q2:Q86)
    j'ai les dates dans le F et les montants en Q

  6. #6
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    une question .. , sais-tu combien comporte de ligne environ ton tableau ? y a-t-il plusieurs années dans ce même tableaux (d'ou plusieurs fois le mois 2 par exemple..)

  7. #7
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Dans un sommeprod il faut que les plages soient sur le même nombre de ligne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =sommeprod((F2:F65536>=date(2011;6;1))*(F2:F65536<=DATE(2011;6;30));Q2:Q65536)
    Jérôme

  8. #8
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    à Jérôme : c'est exactement ce que j'ai fait mais ça ne marche pas.
    à Bbil : pour l'instant j'ai que l'année 2011 et pour chaque mois y a plusieurs enregistrements ( ex mois mars j'ai 01/03/2011, 03/03/2011 , 15/03/2011 et 27/03/2011)

  9. #9
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Donc tu ne dois pas avoir beaucoup de ligne une boucle te permet la mise à jour de tes 12 totaux

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
     
    Sub CalculTotaux()
       Dim rTotal(1 To 12) As Double
       Dim sh As Worksheet
       Const ANNEE = 2011 ' A voir comment tu veut définir l'année concernée
       Const icDTE = 1 ' colonne de date (A)
       Const icDONN = 2 ' colonne donnée (B)
       Dim iMax As Integer 'Nombre de lignes à traiter
       Dim i As Integer 'index de ma boucle
       Dim iMois As Integer 'Numero de mois
       Set sh = Workbooks("Classeur1").Sheets("Feuil4") ' Définit la feuille concernée..
       iMax = sh.Range("A1").CurrentRegion.Count
     
       For i = 2 To iMax ' on part de 2 si ligne 1 = Titre
          If Year(sh.Cells(i, icDTE)) = ANNEE Then ' Seule les Année 2011 sont concerné
                iMois = Month(sh.Cells(i, icDTE))  'récupére le numéro de mois
                rTotal(iMois) = rTotal(iMois) + sh.Cells(i, icDONN)
          End If
       Next
    '-----------------------------------
    ' Pour terminer affichage résultat dans fenêtre exécution (CTRL+G
    For i = 1 To 12
      Debug.Print "Total " & i & " : " & rTotal(i)
    Next
    Stop 'CTRL+G pour voir le résultat
    End Sub

Discussions similaires

  1. [AC-2007] Faire une somme d'un champ en fonction d'une periode
    Par Rambov dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 12/03/2010, 13h25
  2. [XL-2003] Faire une somme avec la fonction sous total
    Par Gwladys dans le forum Excel
    Réponses: 2
    Dernier message: 09/04/2009, 17h26
  3. Réponses: 9
    Dernier message: 18/02/2008, 11h25
  4. Réponses: 13
    Dernier message: 05/11/2007, 09h00
  5. [Conception] Faire une somme de valeurs définies par une boucle
    Par fixbraun dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 25/09/2006, 23h46

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo