Excel Downloads
Forum

Précédent   Excel Downloads Forums > Archives > Forum Excel Downloads - Archives


 
 
LinkBack Outils de la discussion
Vieux 30/12/2004, 21h13   #1 (permalink)
Hervé
Guest
 
Messages: n/a
Par défaut boucle sur controle pour une virgule à la place du point

Bonsoir tout le monde

je travaille sur un userform avec une quarantaine de textbox.

Je recherche une combine pour lors de la validation des données, vérifier en une seule boucle si des points on été saisie en lieu et place de virgule dans les controles (textbox ou combobox).

j'avais pensé à ceci (merci de pas vous marrer) :

dim ctrl as object
For Each ctrl In UserForm3.Controls
If IsNumeric(ctrl) = True Then
ctrl = Application.WorksheetFunction.Substitute(ctrl, ".", ",")
End If
Next ctrl

mais ceci ne marche pas (et cours encore moins).

Si vous pouviez me donner une solution globale pour éviter la saisie du point au lieu de la virgule ou me renvoyer vers un lien.

D'avance je vous en remercie

Salut
Hervé
 
ANNONCES
Vieux 30/12/2004, 22h04   #2 (permalink)
Hervé
Guest
 
Messages: n/a
Par défaut Re: boucle sur controle pour une virgule à la place du point

re

petite précision, je pense que l'on doit passer par un module de classe, type :

Public WithEvents TxtBox As MSForms.TextBox
Private Sub TxtBox_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
If KeyAscii = Asc(",") Then KeyAscii = Asc(".")
End Sub

mais ensuite, au niveau du module, je ne sais pas comment faire référence à ce code.

d'avance merci

Salut
Hervé
 
Vieux 30/12/2004, 22h26   #3 (permalink)
myDearFriend
Guest
 
Messages: n/a
Par défaut Re: boucle sur controle pour une virgule à la place du point

Bonsoir Hervé, le Forum.


Ci-joint un exemple avec un module de classe qui remplacera le "Point" en "Virgule" lors de la saisie dans chacun des 36 TextBox...


Cordialement.

Didier_mDF
Fichiers attachés
Type de fichier : zip ClassPointEnVirgule.zip (15,9 Ko, 23 affichages)
 
Vieux 30/12/2004, 22h46   #4 (permalink)
Yeahou
Guest
 
Messages: n/a
Par défaut Re: boucle sur controle pour une virgule à la place du point

Bonjour Hervé, didier, Le forum

Si tu dois appliquer sur l'ensemble des texbox, la solution de Didier.

Si tes besoins sont plus ciblés sur certaines texbox et non pas toutes, une simple macro change sur les textbox concernées suffit pour gérer en temps réel.

Private Sub TextBox1_Change()
TextBox1.Value = Replace(TextBox1.Value, ".", ",", 1)
End Sub

ou alors par groupe en ponctuel

For compteur = 1 To 46
UserForm3.Controls("TextBox" & compteur).Value = Replace(UserForm3.Controls("TextBox" & compteur).Value, ".", ",", 1)
Next compteur

Cordialement, A+
 
Vieux 30/12/2004, 22h54   #5 (permalink)
Hervé
Guest
 
Messages: n/a
Par défaut Re: boucle sur controle pour une virgule à la place du point

re

merci Didier et yeahou.

La démo de didier, est à classer dans la catégorie : j'archive avec attention.

Merci encore à vous deux.

Salut
Hervé
 
ANNONCES
 

Liens sociaux

Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are oui
Pingbacks are oui
Refbacks are oui


Fuseau horaire GMT +2. Il est actuellement 10h50.


(C) 2006 Excel Downloads