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 :

Mettre un nom de macro en paramètre et l'exécuter


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    119
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 119
    Points : 64
    Points
    64
    Par défaut Mettre un nom de macro en paramètre et l'exécuter
    salut

    j ai un petit souci
    je voudrais passer une variable a ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    call macro(variable)
    ma variable est un chiffre
    est ce possible ?
    je ne trouve pas le code exact

    merci

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,

    Tu veux passer une variable à une fonction ?

    ceci est un peu flou ...

    Dolphy

  3. #3
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Âge : 61
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 563
    Points : 1 691
    Points
    1 691
    Par défaut
    dans ton cas variable s'appelle un argument et bien sur c'est possible, tu ne nous dis pas ou est le probleme. tu peux essayer d'enlever les parentheses
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub plusdeux(mavariable)
    mavariable = mavariable + 2
    End Sub
    Sub truc()
    a = 5
    plusdeux a
    MsgBox a
    End Sub

  4. #4
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    119
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 119
    Points : 64
    Points
    64
    Par défaut
    je vous file 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
    50
    51
    52
    53
    54
    55
     
    Sub macro1(ligne As Variant, cellul As Variant, cellul2 As Variant, macreau As Variant)
     
    Sheets("Feuil2").Select
    code = Range(ligne).Value
    Sheets("Feuil1").Select
    Range("a1").Value = code
    For i = 1 To Len(code)
    cod = cod + Mid(code, i, 1)
    Next i
    Sheets("feuil1").Select: Range(cellul) = cod
    For i = 1 To Len(cod)
    If Mid(cod, i, 1) >= 0 And Mid(cod, i, 1) <= 9 Or Mid(cod, i, 1) = "." Then affichage = affichage + Mid(cod, i, 1)
    Next i: Sheets("feuil1").Select: Range(cellul2).Value = affichage
     
    If macreau = 2 Then Call macro2
    If macreau = 3 Then Call macro3
    If macreau = 4 Then Call macro4
    If macreau = 5 Then Call macro5
    If macreau = 6 Then Call macro6
    If macreau = 7 Then Call macro7
    If macreau = 8 Then Call macro8
    If macreau = 9 Then Call macro9
    If macreau = 10 Then Call macro10
    If macreau = 11 Then Call macro11
    If macreau = 12 Then Call macro12
    If macreau = 13 Then Call macro13
    If macreau = 14 Then Call macro14
    If macreau = 15 Then Call macro15
    If macreau = 16 Then Call macro16
    If macreau = 17 Then Call macro17
    If macreau = 18 Then Call macro18
    If macreau = 19 Then Call macro19
    If macreau = 20 Then Call macro20
    If macreau = 21 Then Call macro21
    If macreau = 22 Then Call macro22
    If macreau = 23 Then Call macro23
    If macreau = 24 Then Call macro24
    If macreau = 25 Then Call macro25
    If macreau = 26 Then Call macro26
    If macreau = 27 Then Call macro27
    If macreau = 28 Then Call macro28
    If macreau = 29 Then Call macro29
    If macreau = 30 Then Call macro30
    If macreau = 31 Then Call macro31
    If macreau = 32 Then Call macro32
    If macreau = 33 Then Call macro33
    If macreau = 34 Then Call macro34
    If macreau = 35 Then Call macro35
    If macreau = 36 Then Call macro36
    If macreau = 37 Then Call macro37
    If macreau = 38 Then Call macro38
    If macreau = 39 Then Call macro39
    If macreau = "insert" Then Call insert
    End Sub
    j aimerai virer tous ces if et remplacer par un code genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    call macro(macreau)
    ou macreau est mon prametre qui appelle la macro1 puis 2 etc ...

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub Macro1()
        Range("F2").Value = "kjlmkkmù"
    End Sub
     
    Sub laMacro()
        Maquereau = 1
        Application.Run "Macro" & Maquereau
    End Sub
    Teste ça

    Tu peux ajouter le nom du classeur contenant tes macros

  6. #6
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    119
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 119
    Points : 64
    Points
    64
    Par défaut
    nickel
    ca marche avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Application.Run "Macro" & Maquereau
    il vaut donc mieux utiliser ca que call
    merci

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

Discussions similaires

  1. Macro enregistrer en pdf : comment mettre un nom défini ?
    Par alexb' dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 10/01/2014, 09h32
  2. Mettre un nom de paramètre en hyperlien
    Par dakayinzefa dans le forum SSRS
    Réponses: 1
    Dernier message: 19/07/2011, 16h31
  3. mettre un nom d'une colonne d'un dbgrid à partir d'un edit
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 2
    Dernier message: 21/08/2005, 13h30
  4. Mettre le nom du fichier dans TextEdit ?? Avec CFileDialog
    Par P'tit Troll dans le forum Windows
    Réponses: 2
    Dernier message: 19/04/2005, 17h32
  5. Passer le nom de colonne en paramètre d'une procédure stocké
    Par theartist dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 04/01/2005, 15h39

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