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 :

Function compter valeur [XL-2013]


Sujet :

Macros et VBA Excel

  1. #21
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 773
    Points : 28 637
    Points
    28 637
    Billets dans le blog
    53
    Par défaut Fonction personnalisée
    Bonjour,
    Je sais cette discussion résolue mais n'ayant pas pu répondre hier suite à un problème d'affichage de mes discussions, je me permets de publier tout de même la réponse que j'avais préparée.
    Il s'agit d'une fonction personnalisée nommée CountIfSum qui peut donc être utilisée indifféremment avec excel ou avec une procédure VBA.
    Cette fonction renvoie le nombre de fois qu'il y a dans la plage définie dans l'argument Rng, les mots se trouvant dans la chaîne de caractères passée à l'argument Criterias (Les mots doivent être séparés par un point virgule. Exemple : toto;mama;titi

    La fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Function CountIfSum(Rng As Range, Criterias As String) As Long
     ' Arguments
     ' Rng (Range) ' Plage dans laquelle compter les cellules répondant aux critères
     ' Criterias (String) ' Critères à chercher séparés par des ;
     Const FormulaTemplate As String = "=COUNTIF(<Range>, <Criteria>)"
     Dim tbl() As String, Count, Sum, elem
     tbl = Split(Criterias, ";")
     For elem = 0 To UBound(tbl)
      Count = Evaluate(Replace(Replace(FormulaTemplate, "<Range>", Rng.Address), "<Criteria>", Chr(34) & tbl(elem) & Chr(34)))
      Sum = Sum + Count
     Next
     CountIfSum = Sum
    End Function
    Depuis excel (Voir illustration ci-dessous)
    Depuis une procédure VBA
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox CountIfSum(Range("A2:A15"), Range("C2"))
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox CountIfSum(Range("A2:A15"), Join(Array("toto", "mama", "titi"), ";"))
    Illustration de la feuille Excel

    Nom : CountIfSum.jpg
Affichages : 196
Taille : 48,8 Ko
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  2. #22
    Membre éclairé Avatar de Nico Chg
    Homme Profil pro
    Apprenti ingénieur Business Development
    Inscrit en
    Juillet 2014
    Messages
    352
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Apprenti ingénieur Business Development
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2014
    Messages : 352
    Points : 758
    Points
    758
    Par défaut


    Hello, j'étais parti sur un tableau également, mais plus simpliste, je trouve ça bien vu le coup des multi-critères !

    PS (HS) : j'ai également pas mal de problème d'affichage dans le forum ...
    Citation Envoyé par Oscar Wilde
    Je déteste les discussions: elles vous font parfois changer d'avis.

  3. #23
    Membre régulier Avatar de pilounet54
    Homme Profil pro
    retraité
    Inscrit en
    Février 2008
    Messages
    489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : retraité
    Secteur : Service public

    Informations forums :
    Inscription : Février 2008
    Messages : 489
    Points : 89
    Points
    89
    Par défaut
    Citation Envoyé par Philippe Tulliez Voir le message
    Bonjour,
    Je sais cette discussion résolue mais n'ayant pas pu répondre hier suite à un problème d'affichage de mes discussions, je me permets de publier tout de même la réponse que j'avais préparée.
    Il s'agit d'une fonction personnalisée nommée CountIfSum qui peut donc être utilisée indifféremment avec excel ou avec une procédure VBA.
    Cette fonction renvoie le nombre de fois qu'il y a dans la plage définie dans l'argument Rng, les mots se trouvant dans la chaîne de caractères passée à l'argument Criterias (Les mots doivent être séparés par un point virgule. Exemple : toto;mama;titi

    La fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Function CountIfSum(Rng As Range, Criterias As String) As Long
     ' Arguments
     ' Rng (Range) ' Plage dans laquelle compter les cellules répondant aux critères
     ' Criterias (String) ' Critères à chercher séparés par des ;
     Const FormulaTemplate As String = "=COUNTIF(<Range>, <Criteria>)"
     Dim tbl() As String, Count, Sum, elem
     tbl = Split(Criterias, ";")
     For elem = 0 To UBound(tbl)
      Count = Evaluate(Replace(Replace(FormulaTemplate, "<Range>", Rng.Address), "<Criteria>", Chr(34) & tbl(elem) & Chr(34)))
      Sum = Sum + Count
     Next
     CountIfSum = Sum
    End Function
    Depuis excel (Voir illustration ci-dessous)
    Depuis une procédure VBA
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox CountIfSum(Range("A2:A15"), Range("C2"))
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox CountIfSum(Range("A2:A15"), Join(Array("toto", "mama", "titi"), ";"))
    Illustration de la feuille Excel

    Nom : CountIfSum.jpg
Affichages : 196
Taille : 48,8 Ko
    bonjour est merci je ne l'vais pas vue

    j'essaye d'appeler la fonction comme ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ok = CountIfSum(("$A$3:$E$10000"), Join(Array("1", "3", "5", "7", "9", "11", "13", "15", "17", "19")))
    il est pas content avec la plage . Et la question que je me pose avec le critère ("1", "3", "5", "7", "9", "11", "13", "15", "17", "19")
    es que cela peu convenir ?et ou va mes résutats dans mon cas car je ne souhaite pas le MsgBox
    comment je fais svp pour renvoyer les resultats
    merci encore vous Etes tous des pro

    encore merci
    cordialement

  4. #24
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 773
    Points : 28 637
    Points
    28 637
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    il est pas content avec la plage . Et la question que je me pose avec le critère ("1", "3", "5", "7", "9", "11", "13", "15", "17", "19")
    es que cela peu convenir ?et ou va mes résutats dans mon cas car je ne souhaite pas le MsgBox
    comment je fais svp pour renvoyer les resultats
    Je vais essayer de décortiquer chaque question posée au travers de l'utilisation que tu as faites de la fonctionCountIfSum
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ok = CountIfSum(("$A$3:$E$10000"), Join(Array("1", "3", "5", "7", "9", "11", "13", "15", "17", "19")))
    Question 1 : "Il est pas content avec la plage". J'ai pourtant mis trois exemples d'utilisation.
    Dans ton cas, tu l'utilises en VBA. Le premier argument de la fonction est un objet Range, donc c'est Range("$A$3:$E$1000") et pas "$A$3:$E$1000" et tu passes mal également le deuxième argument (il manque un argument à Join ";")
    Question 2
    : "je ne souhaite pas le MsgBox comment je fais svp pour renvoyer les resultats". Il faut savoir comment fonctionne une fonction.
    Une fonction a pour but de renvoyer un résultat et celui-ci, soit tu l'affiches à l'aide de l'instruction MsgBox Fonction() soit tu le stockes dans une variable par Variable = Fonction()

    Conclusion, la véritable syntaxe est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub t()
     Dim OK As Long
     OK = CountIfSum(Range("$A$3:$E$10000"), Join(Array("1", "3", "5", "7", "9", "11", "13", "15", "17", "19"), ";"))
     MsgBox OK
    End Sub
    J'ai mis en rouge les éléments que tu as oublié.
    J'ajouterais que le choix du nom de la variable n'est pas très heureux . Pourquoi OK et pas SommeDesCritères ou encore Total ?
    La programmation demande beaucoup de patience et de rigueur. Je crois que tu n'as bien regardé les exemples que j'ai donné.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #25
    Membre régulier Avatar de pilounet54
    Homme Profil pro
    retraité
    Inscrit en
    Février 2008
    Messages
    489
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : retraité
    Secteur : Service public

    Informations forums :
    Inscription : Février 2008
    Messages : 489
    Points : 89
    Points
    89
    Par défaut
    je pense qu'avec ceci je vais me débrouiller, encore que pas sûr à notre age
    je vais pas mettre résolu pour l'instant même si je pense que cela pourrai le faire ,il faut que je sois bien dedans pour pour entrevoie un résultats
    merci beaucoup en attendant ne t’inquiète pas je mettrai résolu plus tard encore merci
    et si ta besoin de quelque chose tu me demande!

    Le ok j'ai plein plein de fonction intéressant qui sont formulées comme cela je les donnerai au moment de noël sur le forum

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. [AC-2007] Requête - Compter valeurs à double pour même identifiant
    Par skippy86 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 11/10/2012, 17h30
  2. Compter valeurs à partir de la requete
    Par sabefa dans le forum Langage
    Réponses: 2
    Dernier message: 10/09/2012, 15h18
  3. Formule compter valeurs d'une colonne sans doublons
    Par spark_legion dans le forum Modélisation
    Réponses: 2
    Dernier message: 05/05/2011, 14h12
  4. Compter valeur négative colonne read.table
    Par wylenia dans le forum R
    Réponses: 3
    Dernier message: 08/12/2010, 15h21
  5. [XL-2003] Compter valeurs d'une colonne en fonction d'une autre colonne
    Par greggy dans le forum Excel
    Réponses: 2
    Dernier message: 03/11/2009, 12h51

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