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 :

Rassembler les valeurs de plusieurs colonnes sur une seule [XL-365]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Juillet 2023
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2023
    Messages : 11
    Par défaut Rassembler les valeurs de plusieurs colonnes sur une seule
    Bonjour,

    J’ai un tableau de 45 colonnes avec des centaines de lignes. Pour chaque ligne, dans les cellules situées entre la ligne 4 et la ligne 13 incluse, puis entre la ligne 15 et la ligne 24 incluse, on ne compte qu’une seule cellule remplie, toutes les autres sont vides.
    Cela tient au fait que chaque ligne de ce tableau est la réponse d’une personne à un questionnaire pour lesquels les répondants ne pouvaient choisir qu’une seule réponse parmi une suite d’options. Par conséquent, le résultat apparaît éclaté entre de nombreuses colonnes.
    Je souhaiterais créer une colonne qui regroupe pour chaque ligne la seule cellule remplie qui se situe entre la ligne 4 et la ligne 13 incluse, ou bien entre la ligne 15 et la ligne 24 incluse.
    J’ai essayé ça :

    Sub RegrouperCellulesRemplies()
    Dim ws As Worksheet
    Dim lastRow As Long
    Dim i As Long

    ' Spécifiez ici le nom de votre feuille de calcul
    Set ws = ThisWorkbook.Sheets("formulaire 2024 - réponses")

    ' Déterminer la dernière ligne avec des données dans la colonne A (ajustez selon vos besoins)
    lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    ' Parcourir chaque ligne
    For i = 1 To lastRow
    ' Fusionner les valeurs entre la ligne 4 et 13, ou entre la ligne 15 et 24
    ws.Cells(i, 46).Value = FusionnerCellulesRemplies(ws.Range(ws.Cells(i, 1), ws.Cells(i, 45)).Offset(0, 3))
    Next i
    End Sub

    Function FusionnerCellulesRemplies(rng As Range) As String
    Dim cell As Range
    Dim valeurCellule As String

    ' Parcourir chaque cellule dans la plage spécifiée
    For Each cell In rng
    ' Si la cellule n'est pas vide, enregistrer la valeur et quitter la boucle
    If Not IsEmpty(cell.Value) Then
    valeurCellule = cell.Value
    Exit For
    End If
    Next cell

    ' Renvoyer la valeur de la cellule remplie
    FusionnerCellulesRemplies = valeurCellule
    End Function


    en vrai ça ne fonctionne pas du tout, j'ai une erreur 9 ce qui signifie que "l'indice n'appartient pas à la sélection" - qu'il y a un problème avec les indices d'un tableau ou d'une plage qui n'existe pas ou qui est incorrecte.

    Mais mon tableau a bien 45 colonnes, et je suis bloqué. Avez-vous une solution ?

  2. #2
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour,

    L'erreur est sur quelle ligne ? En lisant rapidement, je pense que la ligne la plus susceptible de donner cette erreur est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set ws = ThisWorkbook.Sheets("formulaire 2024 - réponses")
    ce qui voudrait dire simplement qu'il y a une faute de frappe dans le nom de lafeuille....

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Juillet 2023
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2023
    Messages : 11
    Par défaut
    Bien vu, j'ai enlevé les espaces le tiret du 6 et l'accent du nom de fichier et je n'ai plus cette erreur... mais j'en ai une autre !

    erreur de compilation : nom ambigu détecté : FusionnerCellulesRemplies

    Je ne vois pas où est l'ambiguité

  4. #4
    Membre Expert
    Inscrit en
    Décembre 2002
    Messages
    993
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 993
    Par défaut
    Salut, si j'ai bien compris tes besoins, voici une macro qui fait le job:

    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
    Sub RegrouperCellulesRemplies()
        Dim ws As Worksheet
        Dim destRow As Long
        Dim i As Long
        Dim k As Long
     
        ' Spécifie la feuille de calcul
        Set ws = ThisWorkbook.Sheets("formulaire 2024 - réponses")
     
        ' Spécifie la ligne de destination de copie
        destRow = 1
     
        ' Boucle à travers chaque colonne (1 à 45)
        For k = 1 To 45
            ' Boucle à travers chaque plage de lignes (4 à 13, puis 15 à 24)
            For i = 4 To 13
                If Not IsEmpty(ws.Cells(i, k).Value) Then
                    ' Si une cellule est remplie, la copie dans la colonne de destination
                    ws.Cells(destRow, 46).Value = ws.Cells(i, k).Value
                    destRow = destRow + 1
                    Exit For
                End If
            Next i
     
            For i = 15 To 24
                If Not IsEmpty(ws.Cells(i, k).Value) Then
                    ' Si une cellule est remplie, la copie dans la colonne de destination
                    ws.Cells(destRow, 46).Value = ws.Cells(i, k).Value
                    destRow = destRow + 1
                    Exit For
                End If
            Next i
        Next k
    End Sub

  5. #5
    Membre émérite
    Homme Profil pro
    Retraité
    Inscrit en
    Octobre 2022
    Messages
    685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Octobre 2022
    Messages : 685
    Par défaut
    Bonjour

    nom ambigu détecté : FusionnerCellulesRemplies
    Tu as du déclarer deux fois la fonction FusionnerCellulesRemplies

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

Discussions similaires

  1. [XL-2019] Concaténer les valeurs de quatre colonnes en une seule dans un tableau
    Par atk_49 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/09/2019, 10h39
  2. [XL-2007] Rassembler des données de plusieurs feuille sur une seule (synthèse)
    Par CaptainTortue dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 19/09/2019, 16h08
  3. Réponses: 8
    Dernier message: 16/06/2014, 12h14
  4. [AC-2010] Requête: Rassembler les informations de plusieurs lignes en une seule
    Par albayt dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 21/11/2013, 22h05
  5. Afficher plusieur colonnes sur une seule colonne ?
    Par Interruption13h dans le forum Langage SQL
    Réponses: 4
    Dernier message: 04/02/2007, 16h57

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