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 :

Fusion de classeurs et de feuilles


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2015
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2015
    Messages : 1
    Par défaut Fusion de classeurs et de feuilles
    Bonjour. Je suis grand débutant en VBA, et j'ai pour but de créer une macro qui assemble en un même classeur les feuilles de deux classeurs différents, et qui fusionne certaines feuilles portant le même nom.
    Dans un premier temps, j'essaie de simplement rassembler toutes les feuilles des différents classeurs en un même classeur.
    J'utilise le code suivant :

    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 consolide()
      ChDir ActiveWorkbook.Path
      Set classeurMaitre = ActiveWorkbook
      nf = Dir("*.xls") 
      Do While nf <> ""
        If nf <> classeurMaitre.Name Then
          Workbooks.Open Filename:=nf
          For k = 1 To Sheets.Count
            Sheets(k).Copy After:=classeurMaitre.Sheets(classeurMaitre.Sheets.Count)
          Next k
          Workbooks(nf).Close False
        End If
        nf = Dir
      Loop
    End Sub
    Résultat : j'obtiens bien un classeur mais j'ai l'impression que seules deux des feuilles sont copiées à plusieurs reprises ...

    Pourriez-vous m'éclairer sur le problème s'il vous plaît ?
    D'avance, merci de votre aide ... et de votre indulgence

  2. #2
    Membre Expert Avatar de Thautheme
    Homme Profil pro
    salarié
    Inscrit en
    Août 2014
    Messages
    1 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : salarié

    Informations forums :
    Inscription : Août 2014
    Messages : 1 373
    Par défaut
    Bonjour FLSK, bonjour le forum,

    Peut-être comme ça :

    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
    Sub consolide()
    Dim CM As Workbook 'Classeur Maître
    Dim CS As Workbook 'Classeur Source
    Dim K As Byte
     
    ChDir ActiveWorkbook.Path
    Set CM = ActiveWorkbook
     
    nf = Dir("*.xls")
    Do While nf <> ""
        If nf <> classeurMaitre.Name Then
            Workbooks.Open Filename:=nf
            Set CS = ActiveWorkbook
            For K = 1 To CS.Sheets.Count
                CS.Sheets(K).Copy After:=CM.Sheets(CM.Sheets.Count)
            Next K
            CS.Close False
        End If
        nf = Dir
    Loop
    End Sub

Discussions similaires

  1. Réponses: 5
    Dernier message: 23/04/2009, 21h57
  2. verouiller le nom du classeur et des feuilles
    Par DIDIDIDA dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 21/03/2008, 11h02
  3. Ouverture dans le meme classeur avec plusieurs feuilles
    Par Marie69 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 30/10/2007, 18h27
  4. Ouverture d'un classeur à une même feuille
    Par Lexot2 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 24/08/2006, 20h13
  5. [VBA-E] Mise en page de tout le classeur avec nb feuill inconnu
    Par tonf dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 20/04/2006, 15h25

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