Programmation VBA

Elise - 28 mai 2007 à 11:38
blux Messages postés 27831 Statut Modérateur -
Bonjour,
dans un fichier Excel, j'ai fait des macros qui font des calculs à partir de données entrées dans des cellules.
Pb : si l'utilisateur du document se trompe et qu'il entre des données qui ne sont pas des chiffres, les macros bug.
Comment vérifier la nature d'une saisie?
(en l'occurence, comment vérifier que la donnée entrée est bien un chiffre, éventuellement à virgule)
Merci d'avance,
Elise

2 réponses

lermite222 Messages postés 9042 Statut Contributeur 1 191
28 mai 2007 à 11:51
bonjour,
plein de réponses sur les forum.
explore IsNumeric. (tape dans le code IsNumeric, sélectionne le mot et tape F1 tu aurras le mode d'emploi)
A+
louis
0
xjl Messages postés 232 Statut Membre 183
28 mai 2007 à 11:58
Salut,

tu dois pouvoir tester la nature du contenu de la cellule renseignée:

Private Sub Worksheet_Change(ByVal Target As Range)

If IsNumeric(Target.Value) = True Then
'
' Ta macro
'
Else
MsgBox "Merci de rentrer une valeur numérique"
Target.Select
Target.Value = ""
End If
End Sub

A insérer dans le code de la feuille de calcul concernée, et à adapter.... ;-)
0
Merci beaucoup,
c'est exactement la fonction qu'il me fallait!
Elise
0
blux Messages postés 27831 Statut Modérateur 3 364
28 mai 2007 à 13:54
Salut,

il y a aussi IsNull(), si l'utilisateur n'a rien rentré, ce qui évite aux tests de se planter...
0