Microsoft 365 Création d'une macro VBA - copier coller dans un nouveau tableau

dixloup

XLDnaute Nouveau
Bonjour,

Je suis nouveau sur ce forum et novice sur Excel, et j'essaye de progresser notamment sur la conception de macro.
J'ai une liste d'invité renseigné en colonne A, puis en colonne B le regime alimentaire de chaque invité, et en 3ieme colonne j'ai le numéro de la table ou la personne est assise.
Je souhaiterai faire un tableau recapitulatif sur un second classeur où les invités seraient répertoriés par table avec leur régime alimentaire ....
J'ai écris un code, en m'inspirant de divers tuto, le code "fonctionne" (pas de message d'erreur) mais pas d'action de copier coller.

pouvez-vous m'aider ?

Merci pour votre aide
 

Pièces jointes

  • ESSAI MACRO TABLE.xlsm
    19.1 KB · Affichages: 15
Solution
Pour tester j'ai recopié le tableau A2:C12 de la 1ère feuille sur 11 000 lignes.

La macro s'exécute chez moi en 1,1 seconde, c'est tout à fait acceptable.

Mais il y a lieu de revoir la question des bordures, alors utilisez :
VB:
Private Sub Worksheet_Activate()
Dim i&, col As Variant, c As Range
Application.ScreenUpdating = False
Range("A2:V" & Rows.Count).Delete xlUp 'RAZ
With Sheets("LISTE DETAILLE").[A1].CurrentRegion
    For i = 2 To .Rows.Count
        col = Application.Match("*" & .Cells(i, 2), Rows(1), 0)
        If IsNumeric(col) Then
            Set c = Cells(Rows.Count, col).End(xlUp)(2)
            c = .Cells(i, 1)
            c(1, 2) = .Cells(i, 3)
        End If
    Next
End With
'---bordures---
With...

Staple1600

XLDnaute Barbatruc
Bonsoir @dixloup , @chaelie2015

Si j'ai bien compris
(ne fonctionne que sur le fichier exemple tel qu'il est agencé)
Code:
Sub test()
For i = 2 To 12
Sheets("TABLES").Cells(2, (i - 2) + (i - 1)).Value = Cells(i, 1).Value
Sheets("TABLES").Cells(2, (i - 2) + (i - 1)).Offset(, 1) = Cells(i, 3).Value
Next
Sheets("TABLES").Cells(1).CurrentRegion.Columns.AutoFit
End Sub
Il faut lancer la macro en étant sur la feuille LISTE DETAILLE
 

dixloup

XLDnaute Nouveau
Le copier coller fonctionne bien, mais j’aimerai que le nom et prénom se copie colle sous la table correspondante dans l’onglet table :

Exemple : si je modifie les 3 premières personnes et que dans la colonne plan de table je les met en table 1 , j’aimerai qu’en exécutant la macro , ces personnes se copie collent avec leur régime alimentaire sous le tableau « table 1 » dans l’onglet « tables »
Et idem si je modifie d’autres personnes en table 2 … j’aimerai qu’ils se collent en dessous de « table 2 »

Je sais pas si c’est plus facile pour créer le code , on peut modifier la colonne plan de table , et plutôt que de mettre le chiffre correspondant à la table , je peux mettre tout en texte « table 1 » « table 2 »… afin que cela corresponde à la première ligne du tableau de l’onglet « tables »
 

chaelie2015

XLDnaute Accro
Le copier coller fonctionne bien, mais j’aimerai que le nom et prénom se copie colle sous la table correspondante dans l’onglet table :

Exemple : si je modifie les 3 premières personnes et que dans la colonne plan de table je les met en table 1 , j’aimerai qu’en exécutant la macro , ces personnes se copie collent avec leur régime alimentaire sous le tableau « table 1 » dans l’onglet « tables »
Et idem si je modifie d’autres personnes en table 2 … j’aimerai qu’ils se collent en dessous de « table 2 »

Je sais pas si c’est plus facile pour créer le code , on peut modifier la colonne plan de table , et plutôt que de mettre le chiffre correspondant à la table , je peux mettre tout en texte « table 1 » « table 2 »… afin que cela corresponde à la première ligne du tableau de l’onglet « tables »
Bonjour
Les exemples permettent d'élucider le problème.
 

Pièces jointes

  • ESSAI MACRO TABLE CHARLIE.xlsm
    22.4 KB · Affichages: 3

job75

XLDnaute Barbatruc
Bonjour dixloup, chaelie2015, JM,

Voyez le fichier joint et cette macro dans le code de la feuille "TABLES" :
VB:
Private Sub Worksheet_Activate()
Dim i&, col As Variant, c As Range
Application.ScreenUpdating = False
Range("A2:V" & Rows.Count).ClearContents 'RAZ
With Sheets("LISTE DETAILLE").[A1].CurrentRegion
    For i = 2 To .Rows.Count
        col = Application.Match("*" & .Cells(i, 2), Rows(1), 0)
        If IsNumeric(col) Then
            Set c = Cells(Rows.Count, col).End(xlUp)(2)
            c = .Cells(i, 1)
            c(1, 2) = .Cells(i, 3)
        End If
    Next
End With
Columns.AutoFit 'ajustement largeurs
End Sub
Elle se déclenche automatiquement quand on active la feuille.

A+
 

Pièces jointes

  • ESSAI MACRO TABLE.xlsm
    22.7 KB · Affichages: 5

dixloup

XLDnaute Nouveau
Bonjour dixloup, chaelie2015, JM,

Voyez le fichier joint et cette macro dans le code de la feuille "TABLES" :
VB:
Private Sub Worksheet_Activate()
Dim i&, col As Variant, c As Range
Application.ScreenUpdating = False
Range("A2:V" & Rows.Count).ClearContents 'RAZ
With Sheets("LISTE DETAILLE").[A1].CurrentRegion
    For i = 2 To .Rows.Count
        col = Application.Match("*" & .Cells(i, 2), Rows(1), 0)
        If IsNumeric(col) Then
            Set c = Cells(Rows.Count, col).End(xlUp)(2)
            c = .Cells(i, 1)
            c(1, 2) = .Cells(i, 3)
        End If
    Next
End With
Columns.AutoFit 'ajustement largeurs
End Sub
Elle se déclenche automatiquement quand on active la feuille.

A+
Bonjour @job75

C'est exactement ce que je cherchais à faire :)
Merci pour votre aide précieuse... et en plus qui s'active quand on se met sur la feuille c'est le petit plus qui fait la différence :)
Merci beaucoup de m'avoir aider sur cette problématique ;)
Merci à @Staple1600 pour sa contribution
et merci à @chaelie2015 de m'avoir aider dans l'explication de mon problème :D pas facile de se faire comprendre quand on baigne pas dans le monde de VBA au quotidien ...
 

job75

XLDnaute Barbatruc
Pour tester j'ai recopié le tableau A2:C12 de la 1ère feuille sur 11 000 lignes.

La macro s'exécute chez moi en 1,1 seconde, c'est tout à fait acceptable.

Mais il y a lieu de revoir la question des bordures, alors utilisez :
VB:
Private Sub Worksheet_Activate()
Dim i&, col As Variant, c As Range
Application.ScreenUpdating = False
Range("A2:V" & Rows.Count).Delete xlUp 'RAZ
With Sheets("LISTE DETAILLE").[A1].CurrentRegion
    For i = 2 To .Rows.Count
        col = Application.Match("*" & .Cells(i, 2), Rows(1), 0)
        If IsNumeric(col) Then
            Set c = Cells(Rows.Count, col).End(xlUp)(2)
            c = .Cells(i, 1)
            c(1, 2) = .Cells(i, 3)
        End If
    Next
End With
'---bordures---
With [A1].CurrentRegion
    .Borders.Weight = xlThin
    For col = 1 To .Columns.Count Step 2
        .Cells(1, col).Resize(.Rows.Count, 2).BorderAround Weight:=xlMedium 'pourtour
    Next
End With
Columns.AutoFit 'ajustement largeurs
End Sub
 

Pièces jointes

  • ESSAI MACRO TABLE.xlsm
    23.4 KB · Affichages: 3

Discussions similaires

Statistiques des forums

Discussions
315 096
Messages
2 116 172
Membres
112 676
dernier inscrit
little_b