Booléen

Fermé
frad - 29 oct. 2004 à 23:52
 frad - 31 oct. 2004 à 00:55
Bonsoir à tous

j'aimerai pouvoir régler un petit problème !

Voila quand j'ouvre une boite de saise pour VBA excel et que je veut traiter l'action "annuler", je la traite par :

nb_ligne = Application.InputBox(Prompt:="NOMBRE DE LIGNE", Title:="prono", _
Type:=1)
If nb_ligne = False Then
Exit Sub
End If

Le probléme est que si je rentre la valeur 0 dans ma boite de dialogue, il prend ca comme False.

Comment puis contourner ca ?

Merci d'avance
A voir également:

4 réponses

gbinforme Messages postés 14946 Date d'inscription lundi 18 octobre 2004 Statut Contributeur Dernière intervention 24 juin 2020 4 711
30 oct. 2004 à 09:44
l'action annuler renvoie une chaine de longueur nulle et il serait préférable de tester "" plutôt que false.

nb_ligne = Application.InputBox(Prompt:="NOMBRE DE LIGNE", Title:="prono", _
Type:=1)
If nb_ligne = "" Then Exit Sub

Dans ce cas, le problème peut se poser si la saisie est vide malgré OK,
mais lorsque l'on demande une saisie elle ne doit pas être absente.

Si l'on renseigne une valeur par défaut cela permet de contrôler.



toujours zen
0
Salut

Mon probleme persiste :
Je fais bien le test avec "" mais si je ne rentre aucune valeur, la procédure continue à s'exécuter sans sortir.

Do
a = Application.InputBox(Prompt:="Pronostic du premier ", Title:="Les plus joués")
If a = "" Then
Exit Sub
End If
Loop Until (a >= 0) And (a <= 8)

Merci de me sauver :)
0
santiago69 Messages postés 477 Date d'inscription mercredi 7 mars 2001 Statut Membre Dernière intervention 12 septembre 2016 209
30 oct. 2004 à 14:53
ca y est, j'ai trouve !
1) pour etre sur de gerer toutes les erreurs, ne précise pas de type d'InputBox :
nb_ligne = Application.InputBox("NOMBRE DE LIGNE", "prono")
2) si la reponse est echap, nb_ligne = Faux
3) si la reponse est rien + OK, nb_ligne = ""
4) si la reponse est qquechose + OK, nb_ligne = qquechose

je propose donc le code suivant (avec plein de boites de message tres enervantes) :
Sub test()
Dim nb_ligne As Variant
Do: nb_ligne = Application.InputBox("NOMBRE DE LIGNE", "prono")
    If nb_ligne = "" Then
        MsgBox "Tu n'a rien saisi avant de faire ""OK"", recommence."
    Else
        If (CStr(nb_ligne) = CStr(False)) Then
            MsgBox "Tu as fait ""Echap"", le programme va s'arreter."
            Exit Sub
        Else
            If IsNumeric(nb_ligne) Then
                MsgBox "Bravo, tu as saisi " & nb_ligne & ", le programme va continuer."
            Else
                MsgBox "Tu n'as pas saisi une valeur numerique, recommence."
            End If
        End If
    End If
Loop Until ((nb_ligne <> "") And IsNumeric(nb_ligne))
End Sub

voila, bon courage et a plus

Il y a 10 types de personnes dans le monde
Ceux qui comprennent le binaire et les autres.
0
Merci pour ton aide mais c'est vrai que c'est plien de boite de dialogue po belle ! Mais j'ai contourner le problème en passant par un userform (qui est bien plus utile pour ce que je cherche à faire)

Cependant, j'ai un autre problème a present dont j'ai lancé le débat sur le forum
0