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 :

Lier textbox à un combobox [XL-2002]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Février 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Transports

    Informations forums :
    Inscription : Février 2012
    Messages : 7
    Par défaut Lier textbox à un combobox
    Bonjour à toutes et à tous,

    Je vous écris car je ne trouve pas solution à mon problème, peut être quelqu'un pourra-t-il m'éclairer.

    Sur une feuille Excel j'ai un tableau :

    la première colonne A : des N° d'article
    la deuxième colonne B : date entrée
    la troisième colonne C : date sortie

    J'ai créé un userform avec :

    - un combobox qui me permet de choisir le N° article
    - textbox 1 qui me permet de rentrer la date 1
    - text box 2 qui me permet de rentrer la date 2

    Or je n'arrive pas à lier les textbox au combobox, de façon à ce que lorsque je sélectionne le n° article dans le combobox je puisse inscrire dans la ligne correspondante les date 1 & 2.

    Quelqu'un aurait-il réponse à mon problème?

    D'avance merci

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Essaie :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Me.TextBox1 = [B2].Offset(Me.ComboBox1.ListIndex)
    Me.TextBox2 = [C2].Offset(Me.ComboBox1.ListIndex)
    ou mieux, pour des dates :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Me.TextBox1 = Format([B2].Offset(Me.ComboBox1.ListIndex), "dd/mm/yyyy")
    Me.TextBox2 = Format([C2].Offset(Me.ComboBox1.ListIndex), "dd/mm/yyyy")

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Février 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Transports

    Informations forums :
    Inscription : Février 2012
    Messages : 7
    Par défaut
    Désolé, Je ne comprend pas ces lignes.

    elle se placent dans Private Sub combobox1_Change() ?

  4. #4
    Membre du Club
    Homme Profil pro
    Inscrit en
    Février 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Transports

    Informations forums :
    Inscription : Février 2012
    Messages : 7
    Par défaut
    Finalement, avec un peu de réflexion, j'ai compris. Merci beaucoup

    Par contre je veux bien une explication de la ligne de code car je ne comprend pas le terme "Me."

  5. #5
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    "Me" représente le module dans laquelle se trouve la macro. Dans le module d'un userform, "Me" équivaut à l'userform :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.TextBox1 = [B2].Offset(Me.ComboBox1.ListIndex)
    équivaut à :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    UserForm1.TextBox1 = [B2].Offset(Me.ComboBox1.ListIndex)
    si tel est le nom de l'userform. Tu n'es pas obligé de le mettre, mais, comme avec le nom de l'userform, une fois tapé le ".", les noms des contrôles apparaissent comme les propriétés et les méthodes, d'où gain de temps à la saisie et moindre risque de faute de frappe.
    De même, dans un module feuille, "Me" équivaut au nome de la feuille attachée au module.

  6. #6
    Membre du Club
    Homme Profil pro
    Inscrit en
    Février 2012
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Transports

    Informations forums :
    Inscription : Février 2012
    Messages : 7
    Par défaut
    Merci pour cette info et surtout grand merci pour m'avoir débloqué de mon problème.

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

Discussions similaires

  1. Changer la couleur des TextBox et Combobox dans un USF
    Par olivepao dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 05/01/2009, 22h41
  2. Textbox vs Combobox avec Textcolumn
    Par Jeyjey1 dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 30/10/2008, 10h42
  3. [WPF] textbox ou combobox dans un listview
    Par modafine dans le forum Windows Presentation Foundation
    Réponses: 5
    Dernier message: 14/08/2008, 11h37
  4. comment vider plusieurs textbox et combobox dans un formilaire et Plus
    Par r.mehdi dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 05/05/2008, 16h52
  5. chaines textbox vers combobox
    Par rober dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 18/10/2006, 09h41

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