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 coller plage de cellule VBA en decalant d'une colonne si remplie [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 10
    Points : 4
    Points
    4
    Par défaut Copier coller plage de cellule VBA en decalant d'une colonne si remplie
    Bonjour,

    Je suis un debutant en VBA et je bloque sur un sujet.
    Sur une feuille j'ai un Tableau Croise Dynamique qui se met a jour quand les donnees changent et je veux ensuite copier et coller ces donnees dans un autre classeur. Or si la premiere colonne est remplie le copier sur la seconde et ainsi de suite...

    J'ai realise ce premier code la qui me met erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Sub Button2_Click()
     
    Worksheets("By_CdG").Range("C2:C51").Copy '--> je selectionne ma plage de cellule a copier
     
    Workbooks.Open ("C:\Thibault\Gestion des litiges\Suivies litiges.xlsm") '--> J'ouvre mon fichier cible
     
    Workbooks("Suivies litiges.xlsm").Activate '--> Je l'active 
     
    Worksheets("By_CdG").Paste Destination:=Worksheets("data").Cells(2, Column.Count).End(xlToRight)(2) '--> Et je copie (je veux que les valeurs et le format)
     
    End Sub
    Or ce code ne mache pas et je me demande pourquoi. J'ai erreur 424 (?)
    Je voudrai ensuite copier ma plage a partir de C2 puis si c'est remplie D2 puis E2...

    Pouvez-vous m'aider svp??

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 617
    Points : 5 912
    Points
    5 912
    Par défaut
    Peut-être ainsi (sans tester...) ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Dim Colonne as Long
    Workbooks.Open ("C:\Thibault\Gestion des litiges\Suivies litiges.xlsm") --> J'ouvre mon fichier cible
     
    Colonne = ActiveWorkbook.Worksheets("data").Cells(2, Columns.Count).End(xlToLeft).Column + 1
    ThisWorkbook.Worksheets("By_CdG").Copy Destination:=ActiveWorkbook.Worksheets("data").Range("C" & Colonne)
    Application.CutCopyMode = False
    End Sub
    PS: pense à utiliser le # quand tu mets du code
    MPi²

  3. #3
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 10
    Points : 4
    Points
    4
    Par défaut
    Avant tout merci parmi de m'aider sur ce sujet.

    Ensuite ta proposition ne fonctionne pas. J'ai une erreur.

    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
     
     
    Sub Button2_Click()
     
    Dim Colonne as Long
     
    Workbooks.Open ("C:\Thibault\Gestion des litiges\Suivies litiges.xlsm") --> J'ouvre mon fichier cible
     
    Colonne = ActiveWorkbook.Worksheets("data").Cells(2, Columns.Count).End(xlToLeft).Column + 1
     
    ThisWorkbook.Worksheets("By_CdG").Copy Destination:=ActiveWorkbook.Worksheets("data").Range("C" & Colonne) --> erreur au niveau de cette phrase. 
     
    Application.CutCopyMode = False
     
    End Sub
    Je ne sais pas du tout pourquoi cela fonctionne pas. J'ai beau chercher mais la j'ai vraiment besoin d'aide svp.

    Merci

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 617
    Points : 5 912
    Points
    5 912
    Par défaut
    Ooops, petit oubli du Range à copier...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ThisWorkbook.Worksheets("By_CdG").Range("C2:C51").Copy .......
    MPi²

  5. #5
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2013
    Messages : 10
    Points : 4
    Points
    4
    Par défaut
    Merci beaucoup parmi pour ton aide!
    Ca marche !

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

Discussions similaires

  1. [XL-2013] Copier/Coller plage de cellules non-vides vers un autre classeur
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 08/06/2015, 15h52
  2. [XL-2007] Copier coller plage de cellules dans une boucle For Each..Next
    Par JulieD33 dans le forum Excel
    Réponses: 3
    Dernier message: 02/03/2015, 11h19
  3. Réponses: 0
    Dernier message: 28/11/2011, 23h41
  4. copier coller plage cellule avec Offset
    Par beebe dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/06/2008, 14h03
  5. [VBA-E] copier /coller sur test cellule
    Par Portsall dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 23/05/2006, 22h19

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