[VBA] : Nombres provenant de textBox dynamiques

Résolu
anton26 Messages postés 31 Date d'inscription   Statut Membre Dernière intervention   -  
anton26 Messages postés 31 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour,

J'ai un programme me permettant de rentrer des notes à l'aide de textBox créées dynamiquement en fonction de la quantité souhaitée. Lorsque je renvoie ces valeurs sur ma feuille excel, mes nombres sont considérés comme du texte. Ainsi,si je souhaite calculer une moyenne c'est impossible. Comment pourrais-je transformer ces valeurs en nombres sachant que ce sont des textBox dynamiques ?
Merci



5 réponses

pijaku Messages postés 12263 Date d'inscription   Statut Modérateur Dernière intervention   2 761
 
Bonjour Messieurs,
Mr Lermitte222,

Excusez l'incruste...

Si tu utilises ce code pour transférer les textbox dans ta feuille :
Worksheets("trimestre 1").Cells(CtrlIndex + 9, 1).Value = Ctrl.Text

il "suffit" de :
1- tester si la saisie dans le contrôle est bien numérique
2- si oui, transformer le contenu du textbox (bien qu'étant composé de nombres, un textbox est toujours "string") en Double si décimale (je penses que s'agissant de notes, on aura des ,5 ou des moyennes à un moment donné. Non?)

'Test si numérique :
If IsNumeric(Ctrl.Text) Then
    Worksheets("trimestre 1").Cells(CtrlIndex + 9, 1).Value = CDbl(Ctrl.Text)
Else
    MsgBox "pas numérique"
End If

Restera, après, le problème d'erreur de saisie de l'utilisateur (point au lieu de virgule et/ou l'inverse...)
En effet, le séparateur décimal peux, selon s'il est utilisé ou non, faire que votre note saisie dans le textbox soit ou non considérée comme décimale.
Le cas échéant on peux utiliser Replace, comme ceci :
'remplace le point par une virgule : 
Ctrl.Text = Replace(Ctrl.Text, ".", ",")
1
lermite222 Messages postés 8724 Date d'inscription   Statut Contributeur Dernière intervention   1 191
 
Re,
Dans ta question précédante sur les TextBox créer en dynamique tu parlais du nom des élèves.
C'est toujours la même chose mais avec des nombres ? entier ou décimale ?
0
anton26 Messages postés 31 Date d'inscription   Statut Membre Dernière intervention  
 
Re,
Oui c'est le même principe mais avec des nombres .
0
lermite222 Messages postés 8724 Date d'inscription   Statut Contributeur Dernière intervention   1 191
 
Re,
@ Heliotte bonjour, Ton principe est le bon
@anton26 Version2 qui prend les deux Texte et nombre

A+
0

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

Posez votre question
anton26 Messages postés 31 Date d'inscription   Statut Membre Dernière intervention  
 
Merci à vous deux. C'est impeccable.
0