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 :

Copie d'une feuille


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de pingoui
    Homme Profil pro
    Activité professionnelle sans liens avec le developpement
    Inscrit en
    Juillet 2004
    Messages
    584
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Activité professionnelle sans liens avec le developpement
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2004
    Messages : 584
    Par défaut Copie d'une feuille
    Bonjour,

    Je débute en VBA et je suis confronté à un petit bogue lors de la copie d'une feuille(ImportedWs) d'un classeur(ImportedWb) vers un autre classeur(DbWb).

    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
     
    Option Explicit
     
    Sub Import(ByVal FileName As String)
     
    Dim DbWb As Workbook, ImportedWb As Workbook
    Dim DbWs As Worksheet, TemporaryWs As Worksheet, ImportedAWs As Worksheet
     
    'Renseignement des variables Workbook et Worksheet de ce classeur
    Set DbWb = ThisWorkbook
    Set DbWs = DbWb.Sheets("Excel_db")
     
    'ouverture du fichier
    Workbooks.Open FileName
     
    'Renseignement des variables Workbook et Worksheet du fichier à importer
    Set ImportedWb = ActiveWorkbook
    Set ImportedWs = ImportedWb.Sheets(1)
     
    ' par ici pour l'erreur 
    'Copie de la feuille à importer dans ce classeur
    ImportedWs.Copy After:=DbWb.Sheets(1)
     
    TemporaryWs = DbWb.Sheets(2)
     
    End Sub
    D'avance, merci pour votre aide
    Cordialement

  2. #2
    Expert confirmé Avatar de Patrice740
    Homme Profil pro
    Retraité
    Inscrit en
    Mars 2007
    Messages
    2 478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Mars 2007
    Messages : 2 478
    Par défaut
    Bonjour,

    au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TemporaryWs = DbWb.Sheets(2)

    écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set TemporaryWs = DbWb.Sheets(2)

    Cordialement
    Patrice

  3. #3
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonsoir,

    Essai avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    'ouverture du fichier
    Set ImportedWb = Workbooks.Open(FileName)
    au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    'ouverture du fichier
    Workbooks.Open FileName
     
    'Renseignement des variables Workbook et Worksheet du fichier à importer
    Set ImportedWb = ActiveWorkbook
    Chez moi ça fonctionne.

    Hervé.

  4. #4
    Membre éclairé Avatar de pingoui
    Homme Profil pro
    Activité professionnelle sans liens avec le developpement
    Inscrit en
    Juillet 2004
    Messages
    584
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Activité professionnelle sans liens avec le developpement
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2004
    Messages : 584
    Par défaut
    Bonjour,

    Merci beaucoup . Effectivement, cela fonctionne !
    De plus, c'est plus propre

    Merci aussi à patrice pour mon oublie de "Set"

  5. #5
    Membre éclairé Avatar de pingoui
    Homme Profil pro
    Activité professionnelle sans liens avec le developpement
    Inscrit en
    Juillet 2004
    Messages
    584
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Activité professionnelle sans liens avec le developpement
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2004
    Messages : 584
    Par défaut
    Bonjour,
    Tout compte fait, le code ne fonctionne pas sur Excel 2007
    (il fonctionne parfaitement sur excel 2003)

    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
     
     
    Sub Import(ByVal FileName As String)
     
    Dim DbWb As Workbook, ImportedWb As Workbook
    Dim DbWs As Worksheet, TemporaryWs As Worksheet, ImportedWs As Worksheet
     
    'Renseignement des variables Workbook et Worksheet de ce classeur
    Set DbWb = ThisWorkbook
    Set DbWs = DbWb.Sheets(1)
     
    'ouverture du fichier
    Set ImportedWb = Workbooks.Open(FileName)
    Set ImportedWs = ImportedWb.Sheets(1)
     
    'Copie de la feuille à importer dans ce classeur
    ImportedWs.Copy After:=DbWb.Sheets(1)
     
    Set TemporaryWs = DbWb.Sheets(2)
    TemporaryWs.Name = "Temp"
     
    End Sub
    Y a t'il une subtilité entre les deux versions d'excel ?

  6. #6
    Expert éminent 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
    Par défaut
    Bonjour

    J'ai essayé d'optimiser les variables et testé sur XL2010
    (En effet, déclarer une variable seulement pour renommer une feuille, c'est un peu surdimensionné)
    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
    Sub Import(ByVal FileName As String)
    Dim ImportedWb As Workbook
     
    Application.ScreenUpdating = False
    With ThisWorkbook
        'Supprimer l'éventuelle feuille Temp
        On Error Resume Next
        Application.DisplayAlerts = False
        .Sheets("Temp").Delete
        Application.DisplayAlerts = True
        On Error GoTo 0
        'ouverture du fichier
        Set ImportedWb = Workbooks.Open(FileName)
        'Copie de la feuille à importer dans ce classeur
        ImportedWb.Sheets(1).Copy After:=.Sheets(1)
        'Fermeture fichier et libération de la variable
        ImportedWb.Close False
        Set ImportedWb = Nothing
        'Renommer la feuille importée
        .Sheets(2).Name = "Temp"
    End With
    End Sub

  7. #7
    Membre éclairé Avatar de pingoui
    Homme Profil pro
    Activité professionnelle sans liens avec le developpement
    Inscrit en
    Juillet 2004
    Messages
    584
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Activité professionnelle sans liens avec le developpement
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2004
    Messages : 584
    Par défaut
    Merci beaucoup. Cela fonctionne parfaitement

    La variable TemporaryWs, n'était pas présente uniquement pour nommer la feuille mais j'allais l'utiliser dans le reste de la macro.

    Cordialement

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 15/02/2008, 10h24
  2. [VBA-E] Copie d'une feuille à l'autre
    Par damsmut dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 13/12/2006, 16h52
  3. [VBA-E]Erreur lors de la copy d'une feuille
    Par nattyman dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 07/08/2006, 15h30
  4. [VBA Excel] Copie d'une feuille dans un autre fichier
    Par nattyman dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/08/2006, 11h35
  5. [VBA] Copie d'une feuille (avec graphique)
    Par ed_dexia dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 06/10/2005, 10h56

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