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 :

copier une chaine de caractères [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Directeur de projet
    Inscrit en
    Décembre 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Décembre 2011
    Messages : 3
    Par défaut copier une chaine de caractères
    Bonjour,
    Pour chaque cellule d'une seule colonne, je souhaite déplacer une chaine de caractère pour faciliter ensuite le tri de cette colonne.
    J'ai parfois le Prénom,NOM et parfois seulement NOM.
    J'aimerais avoir NOM,Prénom et quand il n'y a que le NOM aucune modification.
    Utilisatrice peu avertie de VBA, j'ai fais des tests pour repérer les cellules où il y a une virgule et sélectionner ce qu'il y a à gauche de cette virgule pour ensuite le coller à droite du nom mais ça ne fonctionne pas (CHERCHE, STXT...)

    Situation de départ
    Patrice,BERNARD
    Colette, PATISSON
    BARBARA
    Sophie,DAUMER
    RAMEAU

    Situation d'arrivée espérée
    BERNARD,Patrice
    PATISSON,Colette
    BARBARA
    DAUMER,Sophie
    RAMEAU

    Auriez vous des pistes pour m'aider?
    Merci d'avance

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub test()
        Dim c As Range, Tabl
        For Each c In Range([A1], Cells(Rows.Count, 1).End(xlUp))
            Tabl = Split(c.Value, ",")
            If UBound(Tabl) > 0 Then
                c.Value = Tabl(1) & "," & Tabl(0)
            End If
        Next c
    End Sub

  3. #3
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Par formule sans VBA
    Donnée brute en A1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(ESTNUM(TROUVE(",";A1));SUPPRESPACE(STXT(A1;TROUVE(",";A1)+1;NBCAR(A1))&", "&GAUCHE(A1;TROUVE(",";A1)-1));A1)

  4. #4
    Futur Membre du Club
    Femme Profil pro
    Directeur de projet
    Inscrit en
    Décembre 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Décembre 2011
    Messages : 3
    Par défaut Ca fonctionne!
    Bonjour Daniel,
    Ton code fonctionne parfaitement, merci beaucoup.
    J'ai pu l'intégrer dans ma macro complète et ça tourne à merveille.
    J'ai cependant du mal à comprendre comment fonctionne exactement la formule split ( elle scinde le texte en 2 à partir de la virgule et après?) et où va se positionner le tableau créé.
    Bien cordialement
    Sophie

  5. #5
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    C'est ça. "Split" (en anglais, c'est "partager, découper"). découpe la chaîne de caractères en se servant du séparateur fourni (ici, la virgule). Le résultat est un tableau de chaînes de caractères; le premier élément (index 0) désigne la première partie, la seconde partie a l'index 1 etc. Donc ici, s'il y a deux partie, Tabl(0) désigne le prénom et Tabl(1) le nom. Ubound(Tabl) renvoie l'index le plus élevé du tableau. S'il est égal à 0, c'est qu'il n'y a qu'une partie, donc seulement un nom.

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Directeur de projet
    Inscrit en
    Décembre 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Décembre 2011
    Messages : 3
    Par défaut
    Ok, je comprends mieux le rôle de "If UBound(Tabl) > 0 Then" dans le code et finalement l'ensemble. Entre le code et les explications tout devient lumineux.
    Merci de ta réactivité et de la clarté de tes réponses.
    Bien cordialement
    Sophie

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 13/06/2015, 15h03
  2. Réponses: 2
    Dernier message: 22/08/2009, 17h09
  3. Réponses: 5
    Dernier message: 26/04/2007, 15h39
  4. Réponses: 3
    Dernier message: 26/05/2006, 19h49
  5. Réponses: 2
    Dernier message: 06/12/2002, 07h50

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