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 qui ne marche pas d'un classeur à un autre


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 13
    Points : 11
    Points
    11
    Par défaut Copier coller qui ne marche pas d'un classeur à un autre
    La macro que je souhaite réaliser est toute simple,
    il faut:
    - ouvrir deux fichiers (avec des boites de dialogues)
    - créer un autre fichier avec 3 onglets nommés
    - copier chacun des deux fichiers ouverts dans les deux premiers onglets du fichier créé
    - et faire un traitement de mise en forme

    Je pêche dans la 3eme étape et je ne comprend pas du tout pourquoi...

    Voici mon code:

    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    Sub Rectangle1_QuandClic()
     
    Dim xlApp As Excel.Application
    Dim xlBook As Excel.Workbook
    Dim dmm As Excel.Worksheet
    Dim console As Excel.Worksheet
    Dim comp As Excel.Worksheet
     
        'On créer l'objet Excel
        Set xlApp = CreateObject("Excel.Application")
        'On défini le nombre d'onglets (ici 5)
        xlApp.SheetsInNewWorkbook = 3
        'On ajoute un classeur
        Set xlBook = xlApp.Workbooks.Add
     
        'On créer l'objet onglet dans le nouveau classeur créé
        Set dmm = xlBook.Worksheets(1)
        Set console = xlBook.Worksheets(2)
        Set comp = xlBook.Worksheets(3)
        'On affecte un nom aux l'onglets
        dmm.Name = "Valeurs DMM"
        console.Name = "Valeurs console"
        comp.Name = "Comparatif"
     
     
    Classeur = Application.GetOpenFilename("Classeurs Excel,*")
    If Classeur = False Then Exit Sub
    Workbooks.OpenText Filename:=Classeur, DataType:=1, Semicolon:=True, local:=True
    Columns("A:F").Select
    Selection.Copy
    xlBook.dmm.Activate
    'xlBook.Activate
    'dmm.Select
    ActiveSheet.Paste
     
     
    Classeur = Application.GetOpenFilename("Classeurs Excel,*")
    If Classeur = False Then Exit Sub
    Workbooks.OpenText Filename:=Classeur, DataType:=1, Semicolon:=True, local:=True
     
    Columns("A:F").Select
    Selection.Copy
    xlBook.Activate
    console.Select
    ActiveSheet.Paste
     
    xlApp.Visible = True
     
    End Sub

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2009
    Messages : 652
    Points : 1 219
    Points
    1 219
    Par défaut
    Bonjour,

    A tout hasard changez la ligne

    par

    Cordialement.

    PMO

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    633
    Détails du profil
    Informations personnelles :
    Âge : 56
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 633
    Points : 877
    Points
    877
    Par défaut
    Bonjour

    si possible il faut éviter au maximum les Select

    dans ton code remplace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Columns("A:F").Select
    Selection.Copy
    xlBook.dmm.Activate
    'xlBook.Activate
    'dmm.Select
    ActiveSheet.Paste
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Columns("A:F").Copy dmm.Range("A1")
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Columns("A:F").Select
    Selection.Copy
    xlBook.Activate
    console.Select
    ActiveSheet.Paste
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Columns("A:F").Copy console.Range("A1")

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 13
    Points : 11
    Points
    11
    Par défaut
    Je savais bien que c'était un truc a la con ! en tout cas j'ai bien fait de poser le problème ici, comme à chaque fois c'est résolu, j'y ai pourtant passé l'après midi hier

    Merci à vous !

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

Discussions similaires

  1. Copier Coller qui ne fonctionne pas
    Par maitrebanjo dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 22/05/2015, 12h22
  2. Un simple copier coller qui ne marche plus avec selection.copy
    Par nicdodo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/04/2015, 18h19
  3. [XL-2003] copier-coller qui ne fonctionne pas
    Par facteur dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/05/2010, 16h34
  4. copier coller qui ne fonctionne pas
    Par ericdev67 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/12/2009, 10h36
  5. [E-07] Copier/Coller qui ne marche pas
    Par bdx-77 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 26/12/2008, 07h00

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