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

Excel Discussion :

Compter le nombre d'occurrence suivant un critaire


Sujet :

Excel

  1. #1
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Points : 287
    Points
    287
    Par défaut Compter le nombre d'occurrence suivant un critaire
    Bonjour,

    J'ai un tableau de donnée avec une colonne nommé "SAM_Account_Name" qui comporte des noms d'utilisateurs ou des SID.

    Sur un autre tableau, je réalise des statistiques.

    J'aimerai compter le nombre d'occurrence dans la colonne "SAM_Account_Name" où je trouve un SID.

    J'ai une fonction VBA qui me dit si le paramètre passé est un SID ou non

    Code vba : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Function CtrlSid(Sid As String) As String
        Dim regex As Object, str As String
        Set regex = CreateObject("VBScript.RegExp")
        With regex
          .Pattern = "^S-\d-(\d+-){1,14}\d+$"
        End With
        CtrlSid = regex.Test(Sid)
    End Function

    Je pense que je dois utilisé la fonction "NB.SI.ENS" avec la plage de critère, mais je ne sais comment définir le critère
    J'ai essayé quelque chose comme ça : =NB.SI.ENS(G21:G28;CtrlSid(G21:G28)=VRAI) mais cela ne fonctionne pas.

    NB : je ne dois pas passer par une colonne supplémentaire dans la feuille de donnée qui me dirait si la valeur de la colonne "SAM_Account_Name" est VRAI ou FAUX et compter le nombre d'occurrence. En effet, cette feuille de donnée est importé automatiquement d'un fichier CSV généré par un autre logiciel.

    Merci d'avance

  2. #2
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Décembre 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2014
    Messages : 10
    Points : 13
    Points
    13
    Par défaut
    Bonjour

    dans un premier temps le fonction regex.Test retourne un boolean il faudrait donc changer votre code en conséquence avec l'en-tête suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Function CtrlSid(Sid As String) As Boolean
    Une solution possible serait de créer une fonction avec une boucle compteur comme ceci

    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
     Function NbCtrlSid() As integer
    
        Dim ligne as integer
        Dim compteur as integer
    
        compteur=0   
    ' on fait une recherche dans la colonne A de la ligne 1 à la dernière ligne
         For ligne=1 to thisworkbook.Worksheets("nom_de_la_feuille").Range("A" & rows.count).end(xlup).Row
             
                if CtrlSid(thisworkbook.Worksheets("nom_de_la_feuille").Range("A" & ligne))=true then compteur=compteur+1
    
        Next ligne
    
        nbContrlSid=compteur
    
    End function

  3. #3
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Points : 287
    Points
    287
    Par défaut
    Merci pour l'histoire du Boolean. Ca résous un autre problème que j'avais avec cette fonction.

    Par rapport à ta fonction, on ne peux pas faire la même chose avec une formule matricielle ?

    Genre {=NB.SI.ENS(G21:G28;CtrlSid(G21:G28)=VRAI)}

    A mon avis ma fonction vba n'est pas compatible avec les matrices pour fait ça.

  4. #4
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Décembre 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2014
    Messages : 10
    Points : 13
    Points
    13
    Par défaut
    Peut-être ceci :

    =SOMMEPROD((CtrlSid(G21:G28)=VRAI)*1)

  5. #5
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Points : 287
    Points
    287
    Par défaut
    non, j'ai un #VALEUR!

  6. #6
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Décembre 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 28
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2014
    Messages : 10
    Points : 13
    Points
    13
    Par défaut
    Tu as vérifié que l'erreur ne vient pas de CtrlSid ?

  7. #7
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Points : 287
    Points
    287
    Par défaut
    Si je fais "=CtrlSid(G21)", j'ai VRAI (car je suis sur un SID)

  8. #8
    Membre actif
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Points : 287
    Points
    287
    Par défaut
    Je ne sais pas si Excel sait gérer des patterns complexe comme les regex.

    Car cela serai plus simple de faire quelque chose comme ca "=NB.SI.ENS(matrice;"S-*-*-*-*-*-*-*")" (cette dernière fonctionne, mais ce n'est pas très fiable)

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/04/2008, 16h19
  2. Compter le nombre d'occurrences
    Par RKU01 dans le forum Langage
    Réponses: 1
    Dernier message: 22/03/2008, 17h22
  3. Réponses: 5
    Dernier message: 17/02/2008, 12h32
  4. Réponses: 2
    Dernier message: 06/05/2007, 23h43
  5. [débutant] Compter le nombre d'occurrence d'un texte
    Par PoichOU dans le forum Langage
    Réponses: 2
    Dernier message: 14/10/2006, 00h00

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