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 :

Concaténer pour obtention d'une variable [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Inscrit en
    Novembre 2010
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 21
    Points : 15
    Points
    15
    Par défaut Concaténer pour obtention d'une variable
    Bonjour,

    J'essaie de contrôler un grand nombre de liste déroulante en utilisant une string avec une variable incrémentielle. J'ai besoin de pouvoir accéder à la valeur contenu dans ComboBox9, 11, 13, 15 jusqu'à 169. (Je n'ai pas fait ma boucle while encore dans mon extrait de Code). Je ne trouve pas la bonne syntaxe pour que VBA identifie (ComboBox & i) en tant que la liste déroulante ComboBox9. En bref je veux pouvoir faire (ComboBox & i).value

    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
    Dim i As Integer
    i = 9
    Dim box As String
    box = "ComboBox"
    Dim BoxSet As String
    BoxSet = box & i
    Dim BoxResult As String
    BoxResult = BoxSet.Value
     
        ChDir "C:\Users\Desktop\Grille de montage en attente"
        Workbooks.Open Filename:= _
            "C:\Users\Desktop\Grille de montage en attente\Grille Montage V2-1.xlt" _
            , Editable:=True
            Sheets("SITE Principal").Select
        Range("B36").Value = BoxSet.Value
        ChDir "C:\Users\Desktop\Test_Macro"
        ActiveWorkbook.SaveAs Filename:= _
            "C:\Users\Desktop\Test_Macro\Grille Montage V2-1 test.xlt", _
            FileFormat:=xlTemplate8, Password:="", WriteResPassword:="", _
            ReadOnlyRecommended:=False, CreateBackup:=False
            ActiveWorkbook.Close
    Votre aide est très apprécié.

  2. #2
    Membre chevronné Avatar de rvtoulon
    Homme Profil pro
    Agent Technique
    Inscrit en
    Mars 2009
    Messages
    1 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Agent Technique
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 042
    Points : 2 003
    Points
    2 003
    Par défaut
    bonjour,
    En bref je veux pouvoir faire (ComboBox & i).value
    essaye dans ta boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Userform1.Controls("Combobox" & i).Value

  3. #3
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Salut,

    Juste une question rvtoulon, comment faire la meme chose si l'object est sur la feuille. j'ai su mais me souviens plus

  4. #4
    Membre chevronné Avatar de rvtoulon
    Homme Profil pro
    Agent Technique
    Inscrit en
    Mars 2009
    Messages
    1 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Agent Technique
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 042
    Points : 2 003
    Points
    2 003
    Par défaut
    Bonjour jfontaine,
    il me semble que ceci doit fonctionner:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Dim obj As OLEObject
    i = 1
    'Si control active x de formulaire
     'boucle sur chaque objet de la feuille
     For Each obj In ActiveSheet.OLEObjects
     'si l'objet est un combobox alors
      If TypeOf obj.Object Is MSForms.ComboBox Then
        vnom = obj.Object.Value
        MsgBox "La valeur du Combobox" & i & " est " & vnom
        i = i + 1
      End If
     Next obj
    EDIT: Regarde ici pour plus de détails sur les autres types de control:http://excel.developpez.com/faq/?page=ObjFormulaire

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

Discussions similaires

  1. Concaténer un string avec une variable
    Par nekro65 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 12/03/2009, 11h32
  2. Concaténer le nom d'une variable
    Par PKing dans le forum ActionScript 3
    Réponses: 2
    Dernier message: 06/05/2008, 23h42
  3. Réponses: 4
    Dernier message: 27/09/2007, 15h05
  4. Probléme pour remplacer = dans une variable
    Par koKoTis dans le forum Scripts/Batch
    Réponses: 18
    Dernier message: 05/06/2007, 13h37
  5. [Tableaux] Concaténation du nom d'une variable
    Par nebule dans le forum Langage
    Réponses: 11
    Dernier message: 18/05/2006, 11h30

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