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 :

vba : Comparer les termes delimités par des virgules entre deux cellules [XL-2007]


Sujet :

Excel

  1. #1
    Membre du Club
    Homme Profil pro
    ingenieur systemes industriels
    Inscrit en
    Août 2011
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingenieur systemes industriels
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2011
    Messages : 53
    Points : 43
    Points
    43
    Par défaut vba : Comparer les termes delimités par des virgules entre deux cellules
    Bonjour,

    Je pars d'une feuille excel source que je dois mettre à jour, en la comparant à une autre feuille excel ayant les memes titres de colonnes.
    Pour simplifier le problème, je dois comparer deux cellules contenant plusieurs termes separés par des virgules.
    Exemple:
    Cell(1,1) = A,B,C,MER ci
    Cell(1,2) = A,C,K
    Je souhaite mettre a jour la Cell(1,2) afin d'obtenir A,C,K,B,MER ci
    A noter que les termes peuvent etre des mots comme des chiffres, contenant des caracteres speciaux et des espaces.
    j'arrive pas a créer une fonction pour delimiter les termes et les comparer un par un
    Merci pour tout aide!!

  2. #2
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    1 733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2012
    Messages : 1 733
    Points : 2 553
    Points
    2 553
    Par défaut
    La fonction existe déjà l'ami! C'est split

    x = Split(cells(1,1),",")
    y = Split(cells(1,2),",")

    après il te suffit de comparer

  3. #3
    Membre du Club
    Homme Profil pro
    ingenieur systemes industriels
    Inscrit en
    Août 2011
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingenieur systemes industriels
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2011
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Merci!
    Etant debutant en vba, je ne connaisais pas cette fonction!

  4. #4
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 677
    Points
    18 677
    Par défaut
    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
    Function Completer$(ByVal S1$, ByVal S2$)
             Dim SP$()
             SP = Split(S1, ",")
     
             For Each MOT In Split(S2, ",")
                 If IsError(Application.Match(MOT, SP, 0)) Then
                     ReDim Preserve SP(UBound(SP) + 1)
                     SP(UBound(SP)) = MOT
                 End If
             Next
     
             Completer = Join(SP, ",")
    End Function
     
     
    Sub Demo()
        Cells(1, 2).Value = Completer(Cells(1, 2).Value, Cells(1, 1).Value)
    End Sub
    __________________________________________________________________________________________

    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion …
    C'est parce que la vitesse de la lumière est plus rapide que celle du son que tant de gens paressent brillants avant d'avoir l'air con ! (Thomas Boishardy)

  5. #5
    Membre du Club
    Homme Profil pro
    ingenieur systemes industriels
    Inscrit en
    Août 2011
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingenieur systemes industriels
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2011
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Merci Marc-L !
    Ca marche parfaitement, mon code etait bcp plus compliqué que celui la, ca m'a permis d'apprendre des nvlles fonctions en vba aussi

    Merci encore une fois!

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 26/04/2015, 06h45
  2. Réponses: 3
    Dernier message: 28/11/2010, 19h56
  3. [MySQL] Remplacer les chiffres à point par des chiffres à virgule
    Par Sekigawa dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 22/12/2008, 14h57
  4. [CSV] Remplacer les points par des virgules
    Par johnkro dans le forum Langage
    Réponses: 4
    Dernier message: 27/11/2008, 19h25
  5. [VBA-E]Ligne separée par des virgules
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 25/04/2006, 14h06

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