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 :

Travailler de manière DYNAMIQUE sur des variables [XL-2003]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 20
    Par défaut Travailler de manière DYNAMIQUE sur des variables
    Bonjour à tous,



    Je cherche désespérément comment utiliser dynamiquement une variable, mes recherches Internet sont totalement infructueuses.



    Je m'explique. J'ai 5 variables, nommées comme ceci (il s'agit juste d'un exemple) :

    - Var16_A_ch
    - Var16_B_ch
    - Var16_C_ch
    - Var16_D_ch
    - Var16_E_ch



    On veut travailler sur le type personnalisé, caractérisé par les lettres "A", "B", "C", "D" et "E". Il y a donc une variable "Type_perso", qui prendra la valeur d'une de ces 5 lettres.



    Mon objectif est d'obtenir la valeur de la variable qui contient cette lettre.
    Selon mon idée, cela donnerait ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Var16_A_ch = 30
    Var16_B_ch = 50
    Var16_C_ch = 10
    Var16_D_ch = 40
    Var16_E_ch = 20
    Type_perso = "D"
    MsgBox FONCTION("Var16_" & Type_perso & "_ch")
    FONCTION serait une fonction de VBA existante qui permettrait de travailler dynamiquement sur une variable. Le message afficherait donc la valeur de 40 (correspondant à la lettre "D").



    Plus généralement, je veux utiliser une variable de manière dynamique via une autre variable. Cela se fait dans un UserForm, dans lequel on peut obtenir la valeur d'un contrôle en le déclarant de manière dynamique, via la fonction "Controls".



    Je ne cherche pas de solutions de secours. Je cherche uniquement à répondre à cette problématique, et savoir si cela est faisable ou pas, et si oui, comment ?



    J'espère avoir été assez clair, en vous remerciant par avance du prendre du temps pour me répondre.



    Bonne soirée à tous.

  2. #2
    Membre Expert
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Par défaut
    Bonsoir,
    voir Switch peut-être

  3. #3
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonsoir,
    Ne sachant pas s'il vaux mieux dire une grosse bêtise plutôt que d'omettre une piste, je me lance et dis peut être une énormité...
    Ce que vous décrivez ressemble, pour moi, à une simple variable tableau. Non?
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim Tablo As Variant
    Tablo = Array("a", "b", "c")
        MsgBox Tablo(0) 'Renvoie "a"
        MsgBox Tablo(1) 'Renvoie "b"
        'etc...
    Ce qui peux effectivement s'adapter aux contrôles d'un USF non?

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 567
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 567
    Par défaut
    peut-être que tu peux l'utiliser de cette manière
    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
     
    Function variable(var)
    variable = ("Var16_" & var & "_ch")
    Select Case variable
    Case "Var16_A_ch"
     variable = 30
    Case "Var16_B_ch"
     variable = 50
    Case "Var16_C_ch"
     variable = 10
    Case "Var16_D_ch"
     variable = 40
    Case "Var16_E_ch"
     variable = 20
    End Select
    End Function
     
    Sub test()
    Type_perso = "D"
    MsgBox variable(Type_perso)
    End Sub
    ça a l'air de correspondre a ce que tu recherche

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Sur cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MsgBox FONCTION("Var16_" & Type_perso & "_ch")
    Le fait d'utiliser des doubles quotes force Excel à interpréter cela comme une chaine de caractère et non une variable.

    Philippe

  6. #6
    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
    Bonjour,

    Je pense que le mieux serait d'utiliser un dictionnaire dont les clés serait le type perso :
    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
     
    Sub Dictionnaire()
     
        Dim Dico As Object
        Dim Type_perso As String
     
        Set Dico = CreateObject("Scripting.Dictionary")
     
        Dico.Add "A", 30
        Dico.Add "B", 50
        Dico.Add "C", 10
        Dico.Add "D", 40
        Dico.Add "E", 20
     
        Type_perso = "D"
     
        MsgBox FONCTION(Dico(Type_perso))
     
    End Sub
    Hervé.

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

Discussions similaires

  1. Travail sur des variables incrémentables
    Par pratick dans le forum Langage
    Réponses: 3
    Dernier message: 05/01/2014, 19h59
  2. [Tableaux] Fonction extract() sur des variables NULL
    Par Tchupacabra dans le forum Langage
    Réponses: 7
    Dernier message: 21/05/2008, 22h34
  3. Appliquer des liens sur des variables PHP
    Par sasaas dans le forum Langage
    Réponses: 3
    Dernier message: 29/03/2008, 16h27
  4. Réponses: 2
    Dernier message: 11/10/2006, 11h21
  5. Réponses: 4
    Dernier message: 15/12/2002, 04h19

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