Pb en vba : traitement chaîne vide = Null

Résolu/Fermé
Jenni - 31 mars 2005 à 08:47
 Jenni - 31 mars 2005 à 10:11
J'ai créé un formulaire de recherche par mot clef sous access avec un text box nommé "mot_clef" et un bouton qui me permet d'ouvrir un autre formulaire.
Je souhaite obliger l'utilisateur à renseigner le text box.
J'ai donc fait un contrôle dans mon bouton qui est le suivant :

Private Sub Commande7_Click()

If mot_clef = Null Then
MsgBox ("Veuillez préciser ...")
Else
'Ouverture du formulaire
...
End If

End Sub

Lorsque que mon champ est vide, il reconnait que mot_mot=Null et que Null=Null, mais le problème, c'est que malgrès ça, il passe directement au sinon.
J'aimerai avoir une soution. Merci.

7 réponses

Moi, ça ne marché pas, peut être que je l'ai mal utilisé.
Du coup, j'ai trouvé une autre fonction IsNull() et ça fonctionne, donc c'est cool.
Merci.
Jenni.
10
Essaie la fonction IsEmpty(), ça devrait marcher (enfin j'espère !)

++ =)
2
C'est quand bizarre, je viens de tester ça :
Private Sub CommandButton1_Click()
    my = TextBox1.Value
    If my = "" Then
        MsgBox "vide"
    Else
        MsgBox "pleine"
    End If
End Sub

et ça marche nickel !!!

sinon j'ai pas bien compris ton dernier post, car si tu l'initialises à Null, après tu fais un MyVar = TextBox1.Value, tu la testes et pis vala. nan ?
2
Ceci fonctionne que si la chaine est vide

MyVar = Null ' Affectation de Null.
MyCheck = IsEmpty(MyVar) ' Renvoie False.

MyVar = Empty ' Affectation de Empty.
MyCheck = IsEmpty(MyVar) ' Renvoie True.

si la chaîne est pleine, il faut lui affecter "empty"

et on retombe sur le même problème.
1

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
salut =)

il faut peut-être initialisée ta variable à Null avant de mettre le contenu de ton text box dedans.

Ou bien réaliser ton test en faisant :
if (mot_clef=="") Then


Comme ça il teste plutot si la chaine est vide. car une chaine vide est différente de la valeur Null (en C en tout cas, en VB je ne sais pas.)

++
0
Je sais, en C on fait comme ça, mais en vb, on ne peut pas mettre de double =.
J'ai testé aussi:
mot_clef=""
mot_clef=" "

Enfin, merci quand même.
Jenni.
0
Ok, je vais voir si ça marche.
Merci.
0
Effectivement, ça fonctionne, merci bcp.
0