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 :

saisie semi automatique Combobox VBA


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 4
    Points : 2
    Points
    2
    Par défaut saisie semi automatique Combobox VBA
    Bonjour à tous !

    je galère un peu... beaucoup sur un problème de combobox.
    Voilà ce que j'ai : une feuille avec dans une colonne des noms, une autre colonne des prénoms, une autre avec l'adresse, etc...

    Voilà ce que je veux faire :
    Dans un combo, lors de la saisie d'une lettre, afficher automatiquement la liste déroulante avec UNIQUEMENT les noms qui correspondent à la première lettre tapée. (saisie semi-automatique quoi !)
    Je suis peut-être maso, mais j'ai réussi à le faire avec un peu de code.
    Si ça se trouve c'est possible de faire ça juste avec les propriétés existantes du combo mais je ne sais pas comment.
    Là où je bloque, c'est au moment de la sélection de l'item dans la liste. Vu le code utilisé, l'événement Change est appelé avant le click et le ListIndex est toujours égal à 0.

    Si quelqu'un pouvait m'aider, ce serait génial !!!!
    SVP.
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonjour,
    ces codes correspondent'ils à ta demande ?
    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
    Option Explicit
    'à ne pas oublier, ci-dessous
    Option Compare Text 'mettre en haut du module, après "option explicit"
    Private Sub UserForm_Initialize()
    Dim i As Integer
    With ComboBox1
       For i = 1 To 6
          .AddItem Range("B" & i)
          .List(.ListCount - 1, 1) = Range("C" & i)
          .List(.ListCount - 1, 2) = Range("D" & i)
       Next i
       .SetFocus
    End With
    End Sub
    '_____________________________________________________________
    Private Sub ComboBox1_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
    Dim trouve As String, i As Integer
    trouve = ComboBox1
    With ComboBox1
       .Clear
       For i = 1 To 6
          If Range("b" & i) Like trouve & "*" Then
             .AddItem Range("B" & i)
             .List(.ListCount - 1, 1) = Range("C" & i)
             .List(.ListCount - 1, 2) = Range("D" & i)
          End If
       Next i
       .listindex = 0
    End With
     
    End Sub

  3. #3
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 699
    Points
    6 699
    Par défaut
    Citation Envoyé par fafa44 Voir le message
    Si ça se trouve c'est possible de faire ça juste avec les propriétés existantes du combo mais je ne sais pas comment.

    SVP.
    Exact , vois du côté de la propriété MatchEntry (et de l'exemple de l'aide VBA) et aussi ICI.

    cordialement,

    Didier

  4. #4
    Expert éminent Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Points : 9 548
    Points
    9 548
    Par défaut
    Bonsoir,
    j'avais mis un message pour MatchEntry à mettre sur 1 mais l'ai supprimé afin d'éviter un bug avec le code que je propose, comme je ne connais pas le but exact de la question. Ayant regardé le fichier de fafa44, beaucoup d'erreurs étaient présentes, j'espère donc que mon code servira au moins à fafa44 pour mieux gérer le VBA.

    Bonne soirée

Discussions similaires

  1. [XL-2007] Saisie semi-automatique vba
    Par Rob's dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 04/11/2013, 19h01
  2. [XL-2007] en vba excel saisie semi automatique dans input box
    Par IfIknow dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 07/12/2009, 17h49
  3. combobox et saisie semi-automatique
    Par samgi dans le forum Windows Forms
    Réponses: 2
    Dernier message: 27/06/2007, 16h25
  4. [VBA] Saisie Semi automatique InputBox
    Par cyber-kaiser dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 01/06/2007, 14h30
  5. Saisie semi-automatique dans combobox
    Par method_man dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 04/04/2007, 16h11

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