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

VBA Access Discussion :

enregistrer plusieurs colonnes d'une liste déroulante dans une table


Sujet :

VBA Access

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Juin 2012
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juin 2012
    Messages : 1
    Points : 1
    Points
    1
    Par défaut enregistrer plusieurs colonnes d'une liste déroulante dans une table
    Bonjour,

    Voici ma situation :

    j'ai un formulaire pour ajouter des données à une table.

    J'ai une liste déroulante à partir d'une requête qui me fournit 2 des champs que je souhaite enregistrer, comment faire ?

    Pour l'instant la seule solution que j'ai trouvé étant de faire Deux listes déroulantes avec le choix de colonne liée qui différe pour chacune mais n'y a t'il pas un moyen de faire ça directement?

    Merci!

  2. #2
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 692
    Points : 57 238
    Points
    57 238
    Billets dans le blog
    40
    Par défaut
    bonjour,

    je n'ai pas bien compris la situation. Tu veux mettre chacune des deux colonnes de ton unique liste déroulante dans deux champs différents de l'enregistrement courant, c'est ça ?

    Tu peux répéterrépéterrépéterrépéter avec plus de détails sur la table et le formulaire ?

  3. #3
    Membre régulier
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Juin 2012
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2012
    Messages : 53
    Points : 73
    Points
    73
    Par défaut
    Le but d'une liste déroulante est de sélectionner une option.

    - Si tu veux envoyer 2 informations dans ta table, il te faut 2 listes déroulantes.

    - Si la 2ème information dépend de la 1ère alors dans ton VBA, tu peux fixer par condition SI la valeur de ta 2ème information en fonction de ta 1ère et ainsi supprimer les valeurs superflues de ta liste déroulante.

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Février 2010
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 136
    Points : 169
    Points
    169
    Par défaut
    Dans la même veine que f-leb :

    BonjourBonjourBonjourBonjour

    Je me permets de tenter ma chance à mon tour !
    Si j'ai bien compris, tu veux avoir une seule liste déroulante avec deux colonnes.... non ?

    Si c'est juste ça, crée une liste déroulante à deux colonnes à l'aide de l'assistant et, sur l'évènement After_Update(), tu récupères la valeur de la première colonne avec :
    Me.NomdetaListeDéroulante.Column(0)
    Puis de la deuxième colonne avec :
    Me.NomdetaListeDéroulante.Column(1)

    Et tu récupères donc les valeurs de tes deux colonnes de la liste déroulante, que tu peux insérer dans une table avec un INSERT.

    Je pense que f-leb voulait en arriver là (non ? )

    Cordialement,
    Beub'

  5. #5
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2012
    Messages
    64
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2012
    Messages : 64
    Points : 86
    Points
    86
    Par défaut
    Bonjour,

    Pour appuyer ce que dit Beub' :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub NomDeTaListe_AfterUpdate()
     
    'Récupère la valeur de la colonne 1 puis de la colonne 2
    MaVariable = NomDeTaListe.Column(0)
    MaVariable2 = NomDeTaListe.Column(1)
    'On vérifie que les variables prennent bien les valeurs voulues
    MsgBox(MaVariable)
    MsgBox(MaVariable2)
     
    End Sub
    La première colonne de ta liste est la Column(0), ensuite la seconde est la Column(1) etc etc ...

  6. #6
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 692
    Points : 57 238
    Points
    57 238
    Billets dans le blog
    40
    Par défaut
    Citation Envoyé par Beub' Voir le message
    Je pense que f-leb voulait en arriver là (non ? )
    c'était l'idée en effet, c'est parfaitparfaitparfaitparfait

Discussions similaires

  1. Réponses: 6
    Dernier message: 15/06/2015, 15h39
  2. Réponses: 1
    Dernier message: 02/04/2015, 16h46
  3. Réponses: 4
    Dernier message: 20/02/2012, 16h59
  4. Réponses: 1
    Dernier message: 12/12/2011, 10h07
  5. Réponses: 10
    Dernier message: 15/07/2008, 16h23

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