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-auto dans textbox


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 38
    Par défaut Saisie semi-auto dans textbox
    Bonjour,
    J'ai trouvé ce code qui me va très bien pour mon application, mais les données saisie sont dans un autre onglet
    Comment faire pointer "A1:A11 en rouge sur un autre onglet


    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    ' rentre ici la plage des données en autocomplétion
    Private Const r As String = "A1:A11"
    Private sInput As String
    ' variable de blocage de la procédure Change
    Dim blnStop As Boolean
     
    Private Sub txtInput_KeyDown(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
    ' gestion des touches d'effacement
        If (KeyCode = vbKeyBack) Or (KeyCode = vbKeyDelete) Then
            blnStop = True
        Else
            blnStop = False
        End If
     
    End Sub
     
    Private Sub txtInput_Change()
        Dim sWord As String
     
        If blnStop Then
            blnStop = False
        Else
            sInput = Left(Me.txtInput, Me.txtInput.SelStart)
            sWord = GetFirstCloserWord(sInput)
            If sWord & "" <> "" Then
                blnStop = True
                Me.txtInput.Text = sWord
                Me.txtInput.SelStart = Len(sInput)
                Me.txtInput.SelLength = 999999
            End If
        End If
     
    End Sub
     
    Private Function GetFirstCloserWord(ByVal Word As String) As String
     
        Dim c As Range
        For Each c In ActiveSheet.Range(r).Cells
            If c.Value Like Word & "*" Then
                GetFirstCloserWord = c.Value
                Exit Function
            End If
        Next c
        Set c = Nothing
     
    End Function
    
    Private Sub UserForm_Click()
    
    End Sub
    Merci de votre aide par avance

  2. #2
    Membre émérite Avatar de Nico Chg
    Homme Profil pro
    Apprenti ingénieur Business Development
    Inscrit en
    Juillet 2014
    Messages
    352
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Apprenti ingénieur Business Development
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2014
    Messages : 352
    Par défaut
    Bonjour,

    Tu peux essayer comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Private Const r As String = "Feuil2!A1:A11"
    Ceci dit, je me méfie, car il y a cette ligne plus loin qui récupère un Range dans la feuille active.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For Each c In ActiveSheet.Range(r).Cells
    Si ma première proposition ne marche pas, essaie de changer la ligne ci dessus, en remplaçant ActiveSheet par l'onglet que tu veux.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 38
    Par défaut
    Merci
    Le code bloc ensuite sur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For Each c In ActiveSheet.Range(r).Cells

  4. #4
    Membre émérite Avatar de Nico Chg
    Homme Profil pro
    Apprenti ingénieur Business Development
    Inscrit en
    Juillet 2014
    Messages
    352
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Apprenti ingénieur Business Development
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juillet 2014
    Messages : 352
    Par défaut
    Effectivement, je l'avais mentionné dans mon précédent post.
    Ce n'est pas la peine de spécifier la feuille dans la plage, tu peux laisser A1:A11 ou la plage que tu désire.

    Il te faut changer, dans la ligne que tu me spécifie, la mention "ActiveWorksheet" par la feuille que tu veux, par exemple Worksheets("LaFeuilleQueJeVeux")

    Réecris ensuite
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Private Const r As String = "A1:A11"
    Sans quoi ça va continuer de planter à ladite ligne.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 38
    Par défaut
    Un grand MERCI c'est parfait

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

Discussions similaires

  1. Saisie semi-automatique dans TextBox
    Par zidane22 dans le forum VB 6 et antérieur
    Réponses: 0
    Dernier message: 11/04/2014, 17h25
  2. 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
  3. Saisie semi-automatique dans un formulaire
    Par Harmony dans le forum IHM
    Réponses: 7
    Dernier message: 19/03/2007, 20h35
  4. [HTML] Supprimer la saisie semi automatique dans les balises TEXT
    Par mego dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 25/07/2006, 16h30
  5. Réponses: 1
    Dernier message: 27/10/2005, 21h48

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