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 une macro [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Novembre 2014
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Service public

    Informations forums :
    Inscription : Novembre 2014
    Messages : 9
    Points : 10
    Points
    10
    Par défaut Recopier une macro
    Bonjour à tous,

    Je me permets de me tourner vers vous pour un peu d'aide. J'utilise un fichier excel qui dispose d'une macro (bouton de contrôle). Cette macro permet à la feuille que j'ai constituée d'être dupliquée sur une nouvelle feuille excel en prenant le n° qui lui est donnée (il s'agit en l’occurrence de factures). CA marche très bien!

    Cependant, j'aimerais reproduire ce bouton de macro sur d'autres classeurs (car c'est vraiment très pratique) mais je ne dispose de suffisamment de connaissances malheureusement et mes tentatives ont échoué.
    Voici le code en question:

    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
    Private Sub CommandButton1_Click()
     
    Dim NFeuil As String
        If Range("G11") <> "" Then
            NFeuil = Range("G11")
            If FeuilExist(NFeuil) Then
                Sheets(NFeuil).Activate
                Exit Sub
            Else
                Sheets("Modele").Copy After:=Sheets(ThisWorkbook.Sheets.Count)
                ActiveSheet.Name = NFeuil
     
            End If
        End If
     
    End Sub
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Function FeuilExist(NomFeuil As String) As Boolean
    Dim a
        FeuilExist = False
        On Error GoTo Err1
        a = Sheets(NomFeuil).Range("A1").Value
        FeuilExist = True
        Exit Function
    Err1:
    End Function
    Quelqu'un pourrait m'expliquer comment utiliser ce bouton de commande avec cette macro dans un autre classeur svp? CA m'aiderait beaucoup.
    J'espère que je ne suis pas trop brouillon dans mes explications.
    D'avance merci.

  2. #2
    Inactif  
    Homme Profil pro
    Analyste-Programmeur / Intégrateur ERP
    Inscrit en
    Mai 2013
    Messages
    2 511
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Analyste-Programmeur / Intégrateur ERP
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mai 2013
    Messages : 2 511
    Points : 10 335
    Points
    10 335
    Par défaut
    Bonjour,

    quelles tentatives as-tu essayé et quels ont été les messages indiqués le cas échéant ?

    Normalement, il te suffit d'insérer un bouton dans tes autres fichiers, de réaliser un click droit dessus => affecter une macro

    un nouvel écran s'ouvre pour sélectionner la macro à affecter, la 2 cas possibles :

    - La macro n'existe pas, tu click sur "nouvelle" et tu copies ce code dedans :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Dim NFeuil As String
     If Range("G11") <> "" Then
    NFeuil = Range("G11")
     If FeuilExist(NFeuil) Then
     Sheets(NFeuil).Activate
     Exit Sub
     Else
     Sheets("Modele").Copy After:=Sheets(ThisWorkbook.Sheets.Count)
     ActiveSheet.Name = NFeuil
     
     End If
     End If
    et l'autre partie du code en dessous du 1er End Sub.



    - soit tu as déjà copier ces 2 bouts de code dans un nouveau module, et tu as juste à choisir le nom de la macro dans la liste.



    Après il ne te reste qu'à modifier le code en fonction de tes nouveaux fichiers (par exemple si le nom de la feuille à vérifier / générer, ne se trouve plus en cellule G11).


    Sinon une petite recherche Google, qui mène directement sur le site de Microsoft :

    http://office.microsoft.com/fr-fr/ex...010342137.aspx

  3. #3
    Membre à l'essai
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Novembre 2014
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Service public

    Informations forums :
    Inscription : Novembre 2014
    Messages : 9
    Points : 10
    Points
    10
    Par défaut
    Lorsque je souhaite intégrer un contrôle active X, excel ouvre une fene^tre de dialogue pour me dire: "impossible d'insérer un objet".
    Par contre, je peux insérer un contrôle de formulaire.

    Comment cela se fait-il?

  4. #4
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour
    Plusieurs discussions sur le sujet, regardes, entre autres ici :http://www.developpez.net/forums/d14...inserer-objet/

    et ici http://www.developpez.net/forums/d14...d/#post8066977
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Membre à l'essai
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Novembre 2014
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Service public

    Informations forums :
    Inscription : Novembre 2014
    Messages : 9
    Points : 10
    Points
    10
    Par défaut
    Bonjour,

    Pour le contrôle active x, c'est résolu. Cependant en copiant le code dans le bouton, ça m'affiche ceci:

    Erreur d’exécution '9": l'indice n'appartient pas à la sélection

    Quesako?

  6. #6
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Comme je ne connais pas le code utilisé, peux-tu le publier
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  7. #7
    Membre à l'essai
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Novembre 2014
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Service public

    Informations forums :
    Inscription : Novembre 2014
    Messages : 9
    Points : 10
    Points
    10
    Par défaut
    Bon, j'ai à priori réussi à résoudre mon problème. Merci de vos interventions.

    Cordialement

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

Discussions similaires

  1. [XL-2010] Macro pour recopier une formule dans une cellule
    Par benadry dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 20/09/2013, 12h47
  2. [VB6] Exécuter une macro Access
    Par Nektanebos dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 22/02/2006, 16h32
  3. [VBA-E] [Excel] Lancer une macro à une heure donnée
    Par Lysis dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 16/10/2002, 12h15
  4. Qu'est-ce qu'une macro ?
    Par karli dans le forum Assembleur
    Réponses: 2
    Dernier message: 01/09/2002, 03h38
  5. Réponses: 2
    Dernier message: 22/07/2002, 12h13

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