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 :

Recopier tous les modules à la fois [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut Recopier tous les modules à la fois
    Bonjour le forum,

    Je veux recopier tous les modules d'un classeur vers un autre classeur.

    J'ai ce 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
    Option Explicit
     Sub test()
     Dim wbs As Workbook, wbd As Workbook, v As Object, f As String
     
     Set wbs = Workbooks("Fichier Source.xls")
     Set wbd = Workbooks("Fichier Destination.xls")
     
     If wbd.Sheets.Count < wbs.Sheets.Count Then Exit Sub
     
     With wbs.VBProject
         For Each v In .VBComponents
             If v.Type < 4 Then
                 f = wbs.Path & "\test." & Choose(v.Type, "bas", "cls", "frm")
                 v.Export f
                 wbd.VBProject.VBComponents.Import f
                 Kill f
                 If v.Type = 3 Then Kill Left(f, Len(f) - 1) & "x"
             ElseIf v.Type = 100 Then
                 If v.CodeModule.CountOfLines > 0 Then
                     With wbd.VBProject.VBComponents(v.CodeModule).CodeModule
                         .DeleteLines 1, .CountOfLines
                         .InsertLines .CountOfLines + 1, v.CodeModule.Lines(1, v.CodeModule.CountOfLines)
                     End With
                 End If
             End If
         Next v
     End With
     End Sub
    Ne pas oublier de cocher la case : Faire confiance au projet Visual Basic
    Outils Macros => Sécurité => Editeurs approuvés => Faire confiance au projet Visual Basic

    Et dans les Références, du VBA : Menu Outils => Références
    Cocher => Microsoft Visual Basic for Applications Extensibiilty 5.3

    Ça ne bug pas mais ça ne fait rien!!!
    J'ai du oublier de faire quelque chose!!!
    Quelqu'un aurait-il une astuce?
    Merci pour vos éventuelles réponses
    Cordialement

  2. #2
    Expert éminent
    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
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonjour,

    As-tu fais le test en mode pas à pas (touche F8) ? Il n'y a pas de raison que ça ne fonctionne pas. Le classeur cible doit être ouvert.

    Hervé.

  3. #3
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Bonjour Theze,
    Non pas fait en mode pas à pas. Oui le classeur cible est ouvert.
    Il doit-y avoir un truc que je ne fait pas.
    Merci à toi
    Bien cordialement

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 773
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 773
    Points : 28 637
    Points
    28 637
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Si cette action est ponctuelle, il suffit de glisser les modules d'un classeur vers l'autre.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #5
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Bonsoir Philippe Tulliez,
    Oui je sais mais j'ai déjà utilisé cette macro qui fonctionnait très bien
    J'ai du faire une modif en quelque part.
    Je gratte il faut que je trouve.
    Merci à toi
    Bien cordialement

  6. #6
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Re-bonsoir,
    Je crois que j'ai trouvé!!!
    Je n'ai pas le même nombre de feuilles entre les deux classeurs.
    Si c'est ça peut-on le contourner?
    Merci pour vos éventuelles réponses.
    Bien cordialement

  7. #7
    Expert éminent
    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
    Points : 6 871
    Points
    6 871
    Par défaut
    Un comptage des modules de type 100 (il y en a au moins deux minimum, le classeur et une feuille) avant d'intervenir sur ces derniers.

    Hervé.

  8. #8
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Re-Bonsoir Theze,
    Oulala trop fort pour moi!!!
    Tu peux un peu expliciter stp?
    Merci d'avance.
    Bien cordialement

  9. #9
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Bonjour le forum,
    J'ai essayé de "contourner" le problème en mettant le même nombre de feuilles dans le nouveau classeur.
    Ça bloque sur la ligne du code ci-dessous:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    With wbd.VBProject.VBComponents(v.CodeModule).CodeModule
    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
    Option Explicit
     Sub RecopieModules()
     Dim wbs As Workbook, wbd As Workbook, v As Object, f As String
     
     Set wbs = Workbooks("TOTO.xls")
     Set wbd = Workbooks("ESSAI")
     
     If wbd.Sheets.Count < wbs.Sheets.Count Then Exit Sub
     
     With wbs.VBProject
         For Each v In .VBComponents
             If v.Type < 4 Then
                 f = wbs.Path & "\RecopieModules." & Choose(v.Type, "bas", "cls", "frm")
                 v.Export f
                 wbd.VBProject.VBComponents.Import f
                 Kill f
                 If v.Type = 3 Then Kill Left(f, Len(f) - 1) & "x"
             ElseIf v.Type = 100 Then
                 If v.CodeModule.CountOfLines > 0 Then
                     With wbd.VBProject.VBComponents(v.CodeModule).CodeModule
                         .DeleteLines 1, .CountOfLines
                         .InsertLines .CountOfLines + 1, v.CodeModule.Lines(1, v.CodeModule.CountOfLines)
                     End With
                 End If
             End If
         Next v
     End With
     End Sub
    Peut-être modifier le code?
    Bonne journée à vous tous.
    Cordialement

  10. #10
    Expert éminent
    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
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonjour,

    Ça bloque sur la ligne du code ci-dessous:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    With wbd.VBProject.VBComponents(v.CodeModule).CodeModule
    Dans ce cas, une simple gestion de l'erreur devrait suffire :
    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
    50
    51
    52
    53
     
    Sub RecopieModules()
     
        Dim wbs As Workbook
        Dim wbd As Workbook
        Dim v As VBComponent
        Dim f As String
     
        Set wbs = Workbooks("Classeur Source.xls")
        Set wbd = Workbooks("Classeur Destination.xls")
     
        'If wbd.Sheets.Count < wbs.Sheets.Count Then Exit Sub
     
        With wbs.VBProject
     
            For Each v In .VBComponents
     
                If v.Type < 4 Then
     
                    f = wbs.Path & "\RecopieModules." & Choose(v.Type, "bas", "cls", "frm")
     
                    v.Export f
     
                    wbd.VBProject.VBComponents.Import f
     
                    'suppression module en cours
                    Kill f
     
                    'suppression du .frx
                    If v.Type = 3 Then Kill Left(f, Len(f) - 1) & "x"
     
                ElseIf v.Type = 100 Then
     
                    If v.CodeModule.CountOfLines > 0 Then
     
                        'gestion simplifiée de l'absence du module de la feuille
                        On Error Resume Next
                        With wbd.VBProject.VBComponents(v.CodeModule).CodeModule
     
                            .DeleteLines 1, .CountOfLines
                            .InsertLines .CountOfLines + 1, v.CodeModule.Lines(1, v.CodeModule.CountOfLines)
     
                        End With
     
                    End If
     
                End If
     
            Next v
     
        End With 'wbs.VBProject
     
    End Sub
    attention, dans ton dernier post il manque l'extension :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Set wbd = Workbooks("ESSAI")
    Hervé.

  11. #11
    Membre habitué
    Homme Profil pro
    Moi, je ne fais que passer, excusez le dérangement
    Inscrit en
    Mars 2013
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Moi, je ne fais que passer, excusez le dérangement

    Informations forums :
    Inscription : Mars 2013
    Messages : 645
    Points : 141
    Points
    141
    Par défaut
    Re-Bonjour Hervé,
    Tu as eu pitié d'un "pauvre malheureux"...Ça fonctionne à merveille.
    Chapeau Hervé et encore un GRAND merci pour avoir bien voulu t'intéresser à mon problème.
    Je te souhaite une bonne fin de WE
    Bien cordialement

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

Discussions similaires

  1. [XL-2003] Recopier tous les Modules d'un classeur dans un autre
    Par Un Internaute dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/09/2014, 17h57
  2. [VBA-E]Exporter / importer tous les modules et frm d'un projet
    Par ouskel'n'or dans le forum Contribuez
    Réponses: 6
    Dernier message: 16/03/2013, 18h37
  3. Supprimer tous les modules (d'un fichier donné)
    Par ouskel'n'or dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/06/2007, 12h20
  4. [VBA]Exporter / importer tous les modules et frm d'un projet
    Par ouskel'n'or dans le forum Contribuez
    Réponses: 0
    Dernier message: 12/02/2007, 16h31
  5. Constante commune à tous les modules du projet
    Par Mors_Ubyte dans le forum Access
    Réponses: 1
    Dernier message: 19/07/2006, 14h48

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