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 :

Compter dans un dictionnary [XL-2016]


Sujet :

Macros et VBA Excel

  1. #1
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 254
    Par défaut Compter dans un dictionnary
    Bonjour à tous,

    J'ai une liste d'articles auxquels sont associés une lettre (A, B, C ou rien). Cette liste possède des doublons. Ceux-ci sont de différents formats (Nombre, Texte).

    Du coup, pour obtenir une liste sans doublon j'utilise l'objet Dictionnary en forçant, à l'aide de Cstr(), la mémorisation de la clé en string.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    For i = 13 To Ligne
        Clé = CStr(WsTemp.Range("E" & i))
        Valeur = CStr(WsTemp.Range("F" & i))
     
            If Not MonDico.Exists(Clé) Then MonDico.Add Clé, Valeur
     
    Next i
    Pour pouvoir compter le nombre de A, B, C ou rien, je voulais pouvoir boucler sur toutes les clés afin d'en connaître la valeur associée. Sauf que, je sèche.

    Si vous avez la solution, je suis preneur !

    Ps : Cette partie de procédure est intégrée à une sub plus volumineuse

    Merci, et bonne journée,

  2. #2
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Salut,

    Tu peux utiliser la propriété
    Count
    du dictionnaire.
    Remarque.
    Si
    - tu avais activé la référence Scripting.Runtime
    - tu avais déclaré ton dictionnnaire en Scripting.Dictionary (du moins pendant la phase de développement)
    Alors, cette propriété te serait proposée par l'éditeur VBE.

    Cela dit, tu peux boucler sur toutes les clés du dictionnaire en balayant justement ses clés

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Dim k as Variant
    For Each k in Dico.Keys

  3. #3
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 254
    Par défaut
    Bonjour Marcel,

    Merci pour ta réponse rapide,

    Mon dictionnaire est bien déclaré, sur ça pas de soucis, j'ai normalement fait les choses correctement,

    En ce qui concerne la propriété count, ne sert-elle pas seulement à compter le nombre de clé dans le dictionnaire ?

  4. #4
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    En ce qui concerne la propriété count, ne sert-elle pas seulement à compter le nombre de clé dans le dictionnaire ?
    C'était bien le sens de ta question, non?
    Cela dit, il est possible d'utiliser cette propriété.

    Balayer les clés, comme je l'indique dans la 2ème partie de mon post, est néanmoins préférable.

  5. #5
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 254
    Par défaut
    Non, ma question était de trouver le nombre de A, B, C ou rien :

    J'ai une liste d'articles auxquels sont associés une lettre (A, B, C ou rien)
    Pour pouvoir compter le nombre de A, B, C ou rien
    Désolé si je me suis mal fait comprendre mais c'est bien les items associés aux keys dont j'ai besoin d'en connaître le nombre.

    J'ai testé le for each et ça marche merveilleusement bien ! Merci beaucoup Marcel,

    Belle journée à toi,

  6. #6
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    De rien Trystan, avec plaisir.

    Juste un point
    L'ensemble des items comme celui des clés d'un dictionnaire alimentent automatiquement, chacun, un tableau Array.
    Leur propriété
    Ubound
    suffit donc à connaître le nombre qui t'intéresse.

  7. #7
    Membre extrêmement actif
    Homme Profil pro
    Inscrit en
    Septembre 2013
    Messages
    1 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 1 369
    Par défaut
    Bonjour,

    Exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub ElementsDifferentsDico()
      Set d1 = CreateObject("Scripting.Dictionary")
      Tbl = Range("B2:B" & [b65000].End(xlUp).Row)
      For i = 1 To UBound(Tbl)
         d1(Tbl(i, 1)) = ""
      Next i
      MsgBox d1.Count
    End Sub
    Sous forme de fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Function élémentsDifférents(champ)
      Set d1 = CreateObject("Scripting.Dictionary")
      tbl = champ.Value
      For Each c In tbl
         d1(c) = ""
      Next c
      élémentsDifférents = d1.Count
    End Function
    Pour obtenir une liste sans doublon:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub ListeSansDoublons()
      Set mondico = CreateObject("Scripting.Dictionary")
      For Each c In Range("a2", [a65000].End(xlUp))
        mondico(c.Value) = ""
      Next c
      [C2].Resize(mondico.Count, 1) = Application.Transpose(mondico.keys)
    End Sub
    Boisgontier
    Fichiers attachés Fichiers attachés

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Compter dans une colonne le nb de valeurs communes
    Par kenny49 dans le forum Requêtes
    Réponses: 3
    Dernier message: 23/04/2007, 14h48
  2. Réponses: 3
    Dernier message: 21/10/2006, 12h39
  3. Compter dans une requête Analyse Croisée
    Par jeanchcom dans le forum Access
    Réponses: 14
    Dernier message: 26/09/2006, 08h14
  4. [Tableaux] Compter dans un tableau
    Par CAMB3L dans le forum Langage
    Réponses: 3
    Dernier message: 29/04/2006, 18h23
  5. Compter dans une table
    Par pmithrandir dans le forum Langage SQL
    Réponses: 3
    Dernier message: 01/12/2005, 09h08

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