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 :

Couper coller une colonne


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Inscrit en
    Mai 2009
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 57
    Points : 45
    Points
    45
    Par défaut Couper coller une colonne
    Bonjour, je ne parviens pas à couper coller une colonne dans une autre, voici ce que je fais dans la macro (pour couper la colonne 13 (M) et la réintroduire dans la colonne 17 (Q)):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ThisWorkbook.Sheets("Feuil1").Cells(1, 13).EntireColumn.Select
    Selection.Cut
    ThisWorkbook.Sheets("Feuil1").Cells(1, 17).EntireColumn.Select
    Selection.Paste
    Lorsque j'execute la macro, le bug se produit à la dernière ligne (Selection.Paste), et l'erreur renvoyée est:
    "Erreur 438: propriété ou méthode non gérée par cet objet"

    Selection.paste n'est pas bon?
    Merci d'avance.

  2. #2
    Membre expérimenté Avatar de mayekeul
    Inscrit en
    Août 2005
    Messages
    1 369
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 1 369
    Points : 1 665
    Points
    1 665
    Par défaut
    bonjour,

    tu dois passer par pastespecial

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ThisWorkbook.Sheets("Feuil1").Cells(1, 17).EntireColumn.PasteSpecial xlPasteAll
    Alleï Bonjour chez vous!

  3. #3
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    with sheets("Feuil1")
    .range("M:M").cut range("Q1")
    end with
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  4. #4
    Membre du Club
    Inscrit en
    Mai 2009
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 57
    Points : 45
    Points
    45
    Par défaut
    Merci pour vos réponses, le couper-coller marche avec la solution de mercatog (mais j'ai l'erreur "la méthode paste special de la classe range a échoué" avec la solution de maykeul).

    Par contre, j'ai un nouveau souci maintenant:

    Dans le fichier (hors macro), des formules font intervenir les cellules de la colonne Q (dans laquelle je coupe-colle les résultats de la colonne M lors de la macro). Mais après ce couper-coller, les formules faisant intervenir la colonne Q sont invalides, car les références aux cellules de Q dans les formules sont transformées en "#REF".

    Une solution serait-elle faire un collage spécial pour copier seulement les valeurs de M dans Q (c'était peut-être la signification de "PasteSpecial", mais je n'ai pas réussi à faire fonctionner cette méthode). Avez vous une idée? Merci encore

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 42
    Points : 41
    Points
    41
    Par défaut
    Voici pour transposer une formule, j'ai déjà utiliser ce code :
    Adapte le et ça devrait fonctionner.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Workbooks(WB).Worksheets(1).Activate
    Range(lettre_collone & "3", lettre_collone & "29").Select
    Selection.AutoFill Destination:=Range(lettre_collone & "3", lettre_collone2 & "29"), Type:=xlFillDefault
    Aussi, si tu as plusieurs lignes à couper et copier, pour accélérer, tu peux utiliser :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    buffer=workbooks(wb1).worksheets(1).cells(i,j).value
    workbooks(wb1).worksheets(1).cells(i,j).value=""
    workbooks(wb2).worksheets(1).cell(k,l).value=buffer

  6. #6
    Membre du Club
    Inscrit en
    Mai 2009
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 57
    Points : 45
    Points
    45
    Par défaut
    Merci à tous

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

Discussions similaires

  1. Couper coller une ligne selon condition
    Par NEC14 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 03/05/2019, 08h50
  2. copier /coller une colonne dans un fichier excel
    Par fboss dans le forum VB.NET
    Réponses: 0
    Dernier message: 13/11/2009, 12h33
  3. Copier/coller une colonne dans une table.
    Par moonwar dans le forum Débuter
    Réponses: 2
    Dernier message: 25/10/2009, 17h23
  4. couper coller une ligne
    Par bosk1000 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 11/03/2009, 08h20
  5. copier / coller une colonne
    Par jmlb35 dans le forum VBA Access
    Réponses: 2
    Dernier message: 29/06/2008, 21h10

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