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 :

[VBA-E] Parcourir les Items d'un ComboBox à la recherche d'une string


Sujet :

Macros et VBA Excel

  1. #1
    Expert éminent sénior
    Avatar de Jipété
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10 837
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10 837
    Points : 15 261
    Points
    15 261
    Par défaut [VBA-E] Parcourir les Items d'un ComboBox à la recherche d'une string
    Bonjour,

    Je n'ai rien trouvé dans la FAQ, ni en utilisant "Rechercher" (les titres sont tellement peu explicites... )
    J'ai besoin de parcourir toutes les lignes d'un bête ComboBox pour voir si une string s'y trouve.
    Je pensais que quelquechose comme ça conviendrait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        Dim i As Integer
        Dim s As String
        s = "toto"
        For i = 0 To cbb_Clients.ListCount - 1
            If s Like cbb_Clients.List(i) Then Exit Sub
        Next i
        'Non trouvé, suite du traitement
    mais je gagne l'erreur 9, "l'indice n'appartient pas à la sélection".

    Une idée ?
    Merci d'avance,
    --
    Jean-Pierre
    Il a à vivre sa vie comme ça et il est mûr sur ce mur se creusant la tête : peutêtre qu'il peut être sûr, etc.
    Oui, je milite pour l'orthographe et le respect du trait d'union à l'impératif.
    Après avoir posté, relisez-vous ! Et en cas d'erreur ou d'oubli, il existe un bouton « Modifier », à utiliser sans modération
    On a des lois pour protéger les remboursements aux faiseurs d’argent. On n’en a pas pour empêcher un être humain de mourir de misère.
    Mes 2 cts,
    --
    jp

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    393
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 393
    Points : 451
    Points
    451
    Par défaut
    Il me semble que ta boucle doit aller de 1 à cbb_Clients.ListCount et pas 0... Et oui, c'est ça VBA, les Array commence à 0, mais pas forcément les collections...

  3. #3
    Expert éminent sénior
    Avatar de Jipété
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10 837
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10 837
    Points : 15 261
    Points
    15 261
    Par défaut Ajout de précisions
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        For i = 1 To cbb_Clients.ListCount
    Même cause, même effet...
    --
    Jean-Pierre
    [edit] Des précisions :
    1- aide VBA, rubrique "ListCount, propriété" :
    La valeur de la propriété ListCount est toujours supérieur de 1 à la valeur la plus grande de la propriété ListIndex, parce que les numéros d'index commencent par zéro et que le nombre d'éléments commence par un 1.
    2- aide VBA, rubrique "ListBox, contrôle, List, propriété, exemple"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    ' Exchange contents of columns 1 and 3
        Dim i As Single
        Dim Temp As Single
        For i = 0 To 5
            Temp = ListBox1.List(i, 0)
            ListBox1.List(i, 0) = ListBox1.List(i, 2)
            ListBox1.List(i, 2) = Temp
        Next i
    3- mon code simplifié, avec l'erreur 9 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
        Dim i As Integer
        For i = 0 To (cbb_Clients.ListCount - 1)
            MsgBox cbb_Clients.List(i, 0)
        Next i
    Pourquoi, mais pourquoi des choses aussi simples sont-elles aussi compliquées ? [/edit]
    Il a à vivre sa vie comme ça et il est mûr sur ce mur se creusant la tête : peutêtre qu'il peut être sûr, etc.
    Oui, je milite pour l'orthographe et le respect du trait d'union à l'impératif.
    Après avoir posté, relisez-vous ! Et en cas d'erreur ou d'oubli, il existe un bouton « Modifier », à utiliser sans modération
    On a des lois pour protéger les remboursements aux faiseurs d’argent. On n’en a pas pour empêcher un être humain de mourir de misère.
    Mes 2 cts,
    --
    jp

  4. #4
    Expert éminent sénior
    Avatar de Jipété
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    10 837
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 10 837
    Points : 15 261
    Points
    15 261
    Par défaut
    C'est fou :

    Il aura suffi que je clique sur "Enregistrer" pour que je me débarrasse de l'erreur 9 !

    Again, « Pourquoi, mais pourquoi des choses aussi simples sont-elles aussi compliquées ? »
    --
    Jean-Pierre
    Il a à vivre sa vie comme ça et il est mûr sur ce mur se creusant la tête : peutêtre qu'il peut être sûr, etc.
    Oui, je milite pour l'orthographe et le respect du trait d'union à l'impératif.
    Après avoir posté, relisez-vous ! Et en cas d'erreur ou d'oubli, il existe un bouton « Modifier », à utiliser sans modération
    On a des lois pour protéger les remboursements aux faiseurs d’argent. On n’en a pas pour empêcher un être humain de mourir de misère.
    Mes 2 cts,
    --
    jp

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

Discussions similaires

  1. [VBA] comment modifier les items des collections
    Par tangjuncn dans le forum Général VBA
    Réponses: 2
    Dernier message: 18/02/2014, 16h37
  2. [VB .NET] Copier les Items d'un ComboBox Vers un Autre
    Par D4rkTiger dans le forum Windows Forms
    Réponses: 6
    Dernier message: 06/08/2006, 12h05
  3. [VBA-E] compter les item d'une listbox
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 12/07/2006, 15h29
  4. Réponses: 2
    Dernier message: 05/07/2006, 09h14
  5. [VBA-E] Parcourir les lignes filtrées après un filtre auto
    Par leptitdave dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/10/2005, 13h14

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