Recopier x cellule dans une colonne
Résolu
mchotard
Messages postés
457
Date d'inscription
Statut
Membre
Dernière intervention
-
Patrice33740 Messages postés 8561 Date d'inscription Statut Membre Dernière intervention -
Patrice33740 Messages postés 8561 Date d'inscription Statut Membre Dernière intervention -
Bonjour
J'au crée une 1ère macro pour venir sélectionner la dernière cellule vide d'une colonne "D" à partir de la cellule "D3" et ça marche
Sub SelectionCelVide()
Sheets("Fichier général").Select
Range("D3").End(xlDown).Offset(1, 0).Select
End Sub
Ensuite j'ai une autre macro qui viens copier un nom dans cette cellule. Ca marche bien également
Mon souci c'est la suite : je voudrais que ce nom soit recopier vers le bas 12 fois correspondant au 12 mois de l'année.
dans une colonne "B" j'ai bien les numéro de chaque mois à savoir 1,2,3 ...jusquà 12.
Cette macro me rendrait bien service.
En espérant avoir été suffisamment clair ^pour que vous puissiez m'aider.
Grand merci
J'au crée une 1ère macro pour venir sélectionner la dernière cellule vide d'une colonne "D" à partir de la cellule "D3" et ça marche
Sub SelectionCelVide()
Sheets("Fichier général").Select
Range("D3").End(xlDown).Offset(1, 0).Select
End Sub
Ensuite j'ai une autre macro qui viens copier un nom dans cette cellule. Ca marche bien également
Mon souci c'est la suite : je voudrais que ce nom soit recopier vers le bas 12 fois correspondant au 12 mois de l'année.
dans une colonne "B" j'ai bien les numéro de chaque mois à savoir 1,2,3 ...jusquà 12.
Cette macro me rendrait bien service.
En espérant avoir été suffisamment clair ^pour que vous puissiez m'aider.
Grand merci
A voir également:
- Recopier x cellule dans une colonne
- Déplacer une colonne excel - Guide
- Site x - Guide
- Sites X : Pornhub, YouPorn et Redtube sont de nouveau accessibles en France - Guide
- Trier une colonne excel - Guide
- Colonne word - Guide
3 réponses
Bonjour,
Mets ce nom dans une variable de type String.
Fais une boucle qui va remplir de cette cellule jusqu'à la 12ème plus bas.
Petit exemple de code, faute de mieux :
Cordialement.
Mets ce nom dans une variable de type String.
Fais une boucle qui va remplir de cette cellule jusqu'à la 12ème plus bas.
Petit exemple de code, faute de mieux :
Sub code() Dim Nom As String For i = LaLigneDeLaPremiereCelluleDeCopie To LaLigneDeLaPremiereCelluleDeCopie + 11 Range("C" & i).Value = Nom 'C à remplacer par la colonne Next i End Sub
Cordialement.
Bonjour,
L'opération "Sélectionner" est destinée à un usage manuel de l'utilisateur, en VBA c'est très fortement déconseillé car jamais utile durant la macro, sauf, parfois seulement, à la fin pour restituer la main à l'utilisateur.
L'opération "Sélectionner" est destinée à un usage manuel de l'utilisateur, en VBA c'est très fortement déconseillé car jamais utile durant la macro, sauf, parfois seulement, à la fin pour restituer la main à l'utilisateur.
Bonjour,
NE PAS UTILISER SELECT !!!!
Par exemple :
NE PAS UTILISER SELECT !!!!
Par exemple :
Option Explicit Sub Recopie() Dim c As Range Dim i As Integer Set c = Worksheets("Fichier général").Range("C3").End(xlDown) For i = 1 To 12 Set c = c.Offset(1) c.Value = c.Offset(-1).Value Next i c.Activate 'Si besoin End Sub
merci Patrice33470, ta macro marche super bien. Si je n'abuse pas, pourrais tu l'adapter pour que je puisse recopier 12 fois un nombre fixe de colonne. A savoir au lieu de recopier uniquement la colonne C, je voudrais pouvoir recopier de la colonne "C" à la colonne "O" et toujours 12 fois.
Sans quoi, dois je remplacer tous les "c" de la macro par D et ainsi de suite. Je suis sur que tu as une autre proposition à me faire.
Je te remercie très sincèrement et cordialement
Sans quoi, dois je remplacer tous les "c" de la macro par D et ainsi de suite. Je suis sur que tu as une autre proposition à me faire.
Je te remercie très sincèrement et cordialement
Bonjour,
Pour copier les valeurs des colonnes C à O :
Et si il y a des formules (à tirer) :
Pour copier les valeurs des colonnes C à O :
Option Explicit Sub Recopie() Dim c As Range Dim i As Integer Set c = Worksheets("Fichier général").Range("C3").End(xlDown) For i = 1 To 12 Set c = c.Offset(1) c.Resize(1, 13).Value = c.Resize(1, 13).Offset(-1).Value Next i c.Activate 'Si besoin End Sub
Et si il y a des formules (à tirer) :
Option Explicit Sub Recopie() Dim c As Range Dim i As Integer Dim j As Integer Set c = Worksheets("Fichier général").Range("C3").End(xlDown) For i = 1 To 12 Set c = c.Offset(1) For j = 0 To 12 c.Offset(0, j).FormulaR1C1 = c.Offset(0, j).Offset(-1).FormulaR1C1 Next j Next i c.Activate 'Si besoin End Sub
Un super grand merci Patrice33740, tu as répondu complètement à ma demande. Et je considère donc mon problème comme résolu. Merci à tous ceux qui ont pris du temps pour d'aider.
Bon WE à tous et à bientôt peut-être, enfin le moins possible pour ne pas toujours vous déranger. D'ailleurs je viens d'acheter VBA pour les nuls afin de me perfectionner un plus.
CDLT
Bon WE à tous et à bientôt peut-être, enfin le moins possible pour ne pas toujours vous déranger. D'ailleurs je viens d'acheter VBA pour les nuls afin de me perfectionner un plus.
CDLT
Bonjour
Je te conseille vivement ce cours pour débutants, gratuit et très complet :
ftp://ftp-developpez.com/bidou/Cours/VBA/formationVBA.pdf
Cordialement
Patrice
Je te conseille vivement ce cours pour débutants, gratuit et très complet :
ftp://ftp-developpez.com/bidou/Cours/VBA/formationVBA.pdf
Cordialement
Patrice
sans boucle:
A adapter avec vos variables ligne et colonne
Pourquoi deux macros ??
Merci tout de même pour le dérangement
Le code marche, c'est un exemple. Il faut l'adapter à votre contexte. À défaut, mettez un fichier à dispo
Je suis désolé, mais je n'arrive toujours pas à recopier ma dernière cellule. Je commets surement une erreur dans la macro que je te livre ci-dessous
Sub Recopie() 'pour recopier une cellule 12 fois vers le bas
Sheets("Fichier général").Select
Range("c3").End(xlDown).Select
Dim Nom As String
For i = LaLigneDeLaPremiereCelluleDeCopie To LaLigneDeLaPremiereCelluleDeCopie + 11
Range("C" & i).Value = Nom 'C à remplacer par la colonne
Next i
Voici le résultat que j'obtiens
Col"C" Col"D"
Roy Hubert
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Fichier général
Je peux t'envoyer un fichier si tu le veux, mais je ne connais pas la procédure.
Merci de ton soutien précieux.