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 :

Mauvaise recherche dans une colonne [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    473
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 473
    Par défaut Mauvaise recherche dans une colonne
    Bonjour à vous,

    J'ai une feuille qui fait environ 5000 lignes, je recherche une ligne précise, et ds la colonne B la ligne est tjrs différente !

    exemple:
    une ligne OD100-1
    une autre est D100-1 mais se trouve après

    si je cherche D100-1 il me donne la OD100-1 pourquoi? Je comprend bien que la terminaison est la même !

    Voici le code
    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
     
    Dim Cp As String
    Dim ci As Variant
     
     
    Cp = ListBox1.Value
     
    Set ci = Sheets("feuil1").Columns("B:B").find(What:=Cp)
     
     
    If ci Is Nothing Then
     
     GoTo finfin
     
     
    Else
     
     
    TextBox18 = ci.Offset(0, 0)
     
    End if

    Merci de votre réponse!

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("feuil1").Columns("B:B").find(Cp, LookAt:=xlWhole)
    Edit
    Declare Ci en Range, le Offset(0,0) n'est pas nécessaire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Dim Cp As String
    Dim Ci As Range
     
    Cp = ListBox1.Value
    Set Ci = Sheets("feuil1").Columns("B:B").Find(What:=Cp, LookAt:=xlWhole)
    If Not Ci Is Nothing Then
        TextBox18 = Ci.Value
        Set Ci = Nothing
    Else
        GoTo finfin 'JE N'AIME PAS
    End If

  3. #3
    Membre chevronné
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    473
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 473
    Par défaut
    Citation Envoyé par mercatog Voir le message

    Declare Ci en Range, le Offset(0,0) n'est pas nécessaire
    Pour moi le Offset(0,0) est nécessaire car ensuite ds mon code on trouve
    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
    Dim Cp As String
    Dim ci As Variant
     
     
    Cp = ListBox1.Value
     
    Set ci = Sheets("feuil1").Columns("B:B").find(What:=Cp)
     
     
    If ci Is Nothing Then
     
     GoTo finfin
     
     
    Else
     
     
    TextBox18 = ci.Offset(0, 0)
     TextBox2 = ci.Offset(0, 1)
    ComboBox3 = ci.Offset(0, 3)
    ComboBox2 = ci.Offset(0, 4)
    End if
    Il est vrai que n'avais pas stipulé cette suite !
    Désolé

  4. #4
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Et où est le problème d'écrire ceci?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    TextBox18 = ci.value
    TextBox2 = ci.Offset(0, 1).value
    ComboBox3 = ci.Offset(0, 3).value
    '....

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    473
    Détails du profil
    Informations personnelles :
    Localisation : France, Vendée (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2007
    Messages : 473
    Par défaut
    Merci Mercatog,

    Non il n'y a pas de problème!

    Voici mon code modifié
    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
    Dim Cp As String
    Dim Ci As Range
     
    Cp = ListBox1.Value
    Set Ci = Sheets("feuil1").Columns("B:B").find(What:=Cp, LookAt:=xlWhole)
    If Not Ci Is Nothing Then
     
     
    TextBox18 = Ci.Offset(0, 0)
    TextBox2 = Ci.Offset(0, 1)
    ComboBox3 = Ci.Offset(0, 3)
    ComboBox2 = Ci.Offset(0, 4)
     
     
        Set Ci = Nothing
    Else
        GoTo finfin 'JE N'AIME PAS
    End If
    Et ça fonctionne très bien!
    Pour info pourquoi tu n'aime pas les goto XXXX?

    merci encore!

  6. #6
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Mets ton code en entier, et je te dirai pourquoi je n'aime pas beaucoup les Goto Etiq

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

Discussions similaires

  1. Recherche dans une colonne
    Par wabo67 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 16/01/2009, 18h58
  2. Recherche dans une colonne
    Par wabo67 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 03/01/2008, 12h46
  3. Recherche dans une colonne
    Par david71 dans le forum Access
    Réponses: 4
    Dernier message: 26/06/2007, 21h37
  4. Recherche dans une colonne tableau Word
    Par cath007 dans le forum VBA Word
    Réponses: 2
    Dernier message: 13/06/2007, 18h35
  5. [VBA-E] Recherche dans une colonne
    Par snowkhan dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 03/03/2006, 15h21

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