Création
d'entreprise
Posez votre question Signaler

Pb en vba : traitement chaîne vide = Null [Résolu]

Jenni - Dernière réponse le 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.
Lire la suite 

Pb en vba : traitement chaîne vide = Null »

8 réponses
Réponse
+2
moins plus
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.
Ajouter un commentaire
Réponse
+1
moins plus
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.
Ajouter un commentaire
Réponse
+1
moins plus
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 ?
Ajouter un commentaire
Réponse
+0
moins plus
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.)

++
Jenni - 31 mars 2005 à 08:59
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.
Ajouter un commentaire
Réponse
+0
moins plus
Essaie la fonction IsEmpty(), ça devrait marcher (enfin j'espère !)

++ =)
Ajouter un commentaire
Réponse
+0
moins plus
Ok, je vais voir si ça marche.
Merci.
Ajouter un commentaire
Réponse
+0
moins plus
Effectivement, ça fonctionne, merci bcp.
Ajouter un commentaire
Ce document intitulé « pb en vba : traitement chaîne vide = Null » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?