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 :

Comparer cellule active avec réponse InputBox


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Homme Profil pro
    Employé administratif
    Inscrit en
    Février 2014
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Employé administratif

    Informations forums :
    Inscription : Février 2014
    Messages : 78
    Par défaut Comparer cellule active avec réponse InputBox
    Bonjour,

    Dans une InputBox, je saisis le code numérique suivant: 330097
    Le contenu de la cellule active contient le même code identique, c'est-à-dire 330097
    Dans l'exemple ci-dessous, la cellule active n'est pas coloriée alors que le code est identique.
    ActiveCell.Value ne semble pas être la syntaxe pour la comparaison.

    Quelqu'un peut-il m'apporter la correction nécessaire ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub macro()
    Dim Reponse
    Reponse = InputBox("Taper le code du portefeuille")
    For compteur = 1 To nb_lignes -1
    ActiveCell.Offset(1,0).Select
    If ActiveCell.Value = Reponse Then
    ActiveCell.Interior.ColorIndex = 44
    End If
    Next
    End Sub
    Vous en remerciant par avance.

    Cordialement.

  2. #2
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut



    Bonjour, bonjour !

    Suivre le code en mode pas à pas (via la touche F8) pour vérifier si au moins le code entre dans la boucle
    car si la variable nb_lignes n'est pas initialisée ou vaut seulement 1 …

    A retenir : il est inutile de sélectionner une cellule pour y accéder …

  3. #3
    Membre émérite Avatar de keygen08
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    545
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations forums :
    Inscription : Octobre 2012
    Messages : 545
    Par défaut
    Bonjour
    Pourquoi pas comme ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Sub macro()
    Dim Reponse As String
    dim cell as range
    Reponse = InputBox("Taper le code du portefeuille")
    Set cell = Columns("A").Find(Reponse)
        If Not cell Is Nothing Then
        cell.Interior.ColorIndex = 44
        Else
        MsgBox "Le portefeuille souhaité....."
        End If
    End Sub

  4. #4
    Membre confirmé
    Homme Profil pro
    Consultant fonctionnel
    Inscrit en
    Septembre 2009
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant fonctionnel

    Informations forums :
    Inscription : Septembre 2009
    Messages : 114
    Par défaut
    J'ajoute également que l'instruction InputBox renvoie la réponse sous forme de String. Dans ton cas, "330097" plutôt que 330097.
    Donc pour comparer correctement, il faut que tu forces le format de ta cellule en chaîne de caractères. En reprenant ton code, ça donne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub macro()
    Dim Reponse
    Reponse = InputBox("Taper le code du portefeuille")
    For compteur = 1 To nb_lignes -1
    ActiveCell.Offset(1,0).Select
    If Cstr(ActiveCell.Value) = Reponse Then
    ActiveCell.Interior.ColorIndex = 44
    End If
    Next
    End Sub
    Plus propre à mon goût car tu évites de sélectionner la cellule (recherche effectuée dans la colonne j = 1, de la ligne 1 à 10):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub macro()
    Dim Reponse
    Dim i, j, nb_lignes
    j = 1
    nb_lignes = 10
    Reponse = InputBox("Taper le code du portefeuille")
    For i = 1 To nb_lignes
        If CStr(Cells(i, j).Value) = Reponse Then
            Cells(i, j).Interior.ColorIndex = 44
        End If
    Next
    End Sub

Discussions similaires

  1. [XL-2010] position et valeur d'une cellule avec Application.InputBox
    Par tallent_e dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 23/04/2011, 19h57
  2. [XL-2003] Incrémentation de réponses avec Fonction Inputbox sous VBA
    Par thé-citron dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/03/2011, 17h06
  3. inputbox avec réponse automatiquement validée au bout de 5 sec
    Par tibofo dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 30/01/2009, 15h56
  4. Réponses: 9
    Dernier message: 27/06/2006, 16h55
  5. Comparer l'enregistrement avec le suivant ...
    Par psyco2604 dans le forum ASP
    Réponses: 3
    Dernier message: 01/06/2004, 17h40

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