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 :

Répartir le contenu d'une cellule sur plusieurs lignes


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Répartir le contenu d'une cellule sur plusieurs lignes
    Bonjour,

    Je suis très très intéressée par la réponse dans cette discussion car je suis confrontée au même problème !
    Dans le fichier mis en PJ j'ai, dans la colonne K, des cellules avec des listes de magasins. Je souhaiterais éclater ces données, non pas sur les colonnes adjacentes mais sur des lignes adjacentes.

    La réponse fournie me conviendrait parfaitement mais je ne sais absolument pas comment l'utiliser ...
    Pourriez-vous me dire, pas à pas, comment faire ???

    D'avance merci !
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent sénior
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 203
    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 203
    Points : 14 354
    Points
    14 354
    Par défaut
    Bonjour,

    Mets cette macro dans un module standard et exécute-la :

    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
    Sub test()
        Dim C As Range, Tabl, Plage As Range, Ligne As Long
        'on travaille avec la feuille "Feuil1"
        With Sheets("Feuil1")
            'on affecte à la variable "Plage" les cellules de la colonne A remplies
            'si tu ne comprendds pas cette ligne, dis-le
            Set Plage = .Range(.[A2], .Cells(.Rows.Count, 1).End(xlUp))
        End With
        'on travaille avec la feuille "Feuil2" et avec "Plage" définie préccédemment
        With Sheets("Feuil2")
            'on boucle sur les cellules de Plage
            For Each C In Plage
                '"Split" renvoie un tableau de la cellule de la colonne K
                'tronçonnée en autant de morceaux qu'il y a de ","
                Tabl = Split(C.Offset(, 10), ";")
                'on traite chaque morceau, du premier au dernier
                .[A:C].NumberFormat = "@"
                For i = 0 To UBound(Tabl)
                    Ligne = Ligne + 1
                    .Range(.Cells(Ligne, 1), .Cells(Ligne, 10)).Value = C.Resize(, 10).Value
                    .Cells(Ligne, 11) = Tabl(i)
                Next i
            Next
            .[K:K].EntireColumn.AutoFit
        End With
    End Sub
    Fichiers attachés Fichiers attachés
    Cordialement.

    Daniel

    La plus perdue de toutes les journées est celle où l'on n'a pas ri. Chamfort

  3. #3
    Nouveau Candidat au Club
    Femme Profil pro
    Inscrit en
    Mars 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations forums :
    Inscription : Mars 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Un énorme MERCI
    Merci pour la réponse et la rapidité !!!!
    Cela m'aide ENORMEMENT !!!

  4. #4
    Membre du Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Avril 2016
    Messages
    50
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Avril 2016
    Messages : 50
    Points : 45
    Points
    45
    Par défaut
    bonjour,

    j'aurais besoin de votre aide . J'ai trouver cette macro interessante mais en colonne K , mes données ne sont pas separées par des ; mais elles sont les unes en dessous des autres ( ALT +ENTER ) .

    Pouvez vous m'aider a modifier la macro ?


    Merci d'avance

  5. #5
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 914
    Points : 5 121
    Points
    5 121
    Par défaut
    bonjour
    pour espérer de l'aide il est recommander d'ouvrir ton propre discussion, beaucoup d'amis n'ouvre pas une discussion déja RESOLU
    ben pour commencer je suis aussi débutant mais pour ton cas je crois avec ce code tu supprime l'espace (Alt+entrée p)par un point virgule puis tu applique le code que tu as
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub test()
        Dim Cell As Range
        Dim Plage As Range
        Set Plage = Range("A2:A10")' à adapter
        For Each Cell In Plage
        Cells(Cell.Row, 2) = Replace(Cell.Value, Chr(10), ";")
        Next
    End Sub
    --------------------------------------------------------------*****----------------------------------------------------------------------------
    Bonne Continuation & Plein Succès
    Notre seul pouvoir véritable consiste à aider autrui avec modestie
    ______________________________________________________
    Pour dire merci, cliquer sur et quand la discussion est résolue, penser à cliquer sur le bouton

  6. #6
    Expert éminent sénior 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
    Points : 31 877
    Points
    31 877
    Par défaut
    Remplace ; par Chr(10)
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

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

Discussions similaires

  1. répartir le contenu d'une colonne sur plusieurs colonnes
    Par thierry.drot dans le forum Excel
    Réponses: 1
    Dernier message: 28/10/2012, 11h12
  2. [XL-2003] Répartir le contenu d'une cellule sur plusieurs lignes
    Par Leehan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 10/10/2012, 15h06
  3. [XL-2007] Séparer le contenu d'une cellule en plusieurs lignes
    Par Mimosa777 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 19/12/2011, 17h36
  4. Réponses: 4
    Dernier message: 22/01/2008, 16h59
  5. [TStringGrid] Une cellule sur plusieurs lignes.
    Par Caine dans le forum Delphi
    Réponses: 15
    Dernier message: 28/03/2007, 12h53

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