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

VBA Discussion :

Suppression des doublons dans une variable de type tableau


Sujet :

VBA

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Juin 2006
    Messages
    622
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 622
    Points : 156
    Points
    156
    Par défaut Suppression des doublons dans une variable de type tableau
    Bonjour,

    J'ai une variable de type tableau (disons de dimension 10)

    exemple :

    Celle ci contient des doublons... comment les supprimer et obtenir une nouvelle variable tableau MyTab2() sans doublons ?

    merci

    a+

    Dams'

  2. #2
    Membre habitué
    Homme Profil pro
    Inscrit en
    Juin 2006
    Messages
    622
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 622
    Points : 156
    Points
    156

  3. #3
    Membre habitué Avatar de ecarbill
    Homme Profil pro
    Cyberdocumentaliste
    Inscrit en
    Juin 2004
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Cyberdocumentaliste
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2004
    Messages : 225
    Points : 146
    Points
    146
    Par défaut
    Bonjour à tous
    Je sais que ceci est une vieille discussion, mais je cherchais une fonction pareille et je suis arrivée ici.
    Dans mes lectures, j'ai vu beaucoup de fonctions qui utilisaient des dictionnaires, ou des collections.
    Après plusieurs réflexions, je me suis lancé moi même à écrire une fonction qui n'utilise rien de tout ça.

    Je mets ma fonction pour éventuellement vos commentaires ou aider d'autres personnes.


    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
     
    '----------------------------------------------------------------------------
    '-----------Fonction supprimant les doublons d'un Array ---------------------
    '----------------------------------------------------------------------------
    Function ArraySansDoublons(Montableau As Variant) As Variant
    '----------------------------------------------------------------------------
     
    Dim mTab() As Variant
    Dim SansDoublon() As Variant
     
    mSup = UBound(Montableau)
    mInf = LBound(Montableau)
     
    Nbelement = 1 + mSup - mInf
    ReDim Preserve mTab(1, Nbelement)
     
    'Je vais une copie du tableau avec une colonne supplémentaire qui
    'contiendra 1 si l'element correspondant est un doublon
    'et 0 dans le cas contraire
     
    For i = 0 To Nbelement - 1
        mTab(0, i) = Montableau(mInf + i)
        mTab(1, i) = 0 '0 par defaut aucun element n'est doublon
    Next i
     
    nbUnique = 0
     
    '-----je parcours le tableau, dès que je trouve un element unique, j'en fais une copie
    '----- et je marque 1 devant tous les autres élements ayant la meme valeur
    For i = 0 To Nbelement - 1
        elmt = mTab(0, i)
        estdbl = mTab(1, i)
        If estdbl = 0 Then
            nbUnique = nbUnique + 1
            ReDim Preserve SansDoublon(nbUnique - 1)
            SansDoublon(nbUnique - 1) = elmt
            For j = i + 1 To Nbelement - 1
                If elmt = mTab(0, j) Then
                    mTab(1, j) = 1
                End If
            Next j
        End If
     
    Next i
     
    ArraySansDoublons = SansDoublon
    End Function
    Merci à tous
    Une somme de savoirs en chaque matière, si minime soit-elle, rend n'importe quel benêt, dans un pays de benêts, docte.

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

Discussions similaires

  1. suppression des doublons dans une matrice
    Par Décembre dans le forum MATLAB
    Réponses: 4
    Dernier message: 05/09/2012, 17h52
  2. supprimer des doublons dans une variable
    Par havany dans le forum Linux
    Réponses: 6
    Dernier message: 20/02/2010, 10h31
  3. [XL-2003] suppression des doublons dans une Combobox
    Par karim19 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 08/10/2009, 16h42
  4. Suppression des doublons par une boucle dans une macro
    Par axamen dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/02/2009, 09h37
  5. Des " dans une variable de type String
    Par 4lkaline dans le forum Langage
    Réponses: 6
    Dernier message: 06/11/2006, 14h20

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