Trier les données par ordre croissant via UserForm

  • Initiateur de la discussion Initiateur de la discussion JMR150
  • Date de début Date de début

Boostez vos compétences Excel avec notre communauté !

Rejoignez Excel Downloads, le rendez-vous des passionnés où l'entraide fait la force. Apprenez, échangez, progressez – et tout ça gratuitement ! 👉 Inscrivez-vous maintenant !

JMR150

XLDnaute Nouveau
Bonjour à tous,

Je souhaite améliorer mon fichier qui est une base de données à compléter via un UserForm. Je souhaiterais trier le N° de l'évènement (TextBox1) directement par ordre croissant.
Par exemple, si le N° de l'évènement rentré est le "9", il se placera dans le tableau au-dessus de la ligne qui comporte le N° d'évènement 11. Si je place le N° d'évènement 10, celui-ci se placera entre les N° d'évènements 9 et 11. Je ne sais pas si je suis assez claire. 😕

J'en profite aussi pour poser une question qui paraît toute bête mais je n'y arrive tout simplement pas : 🙁 . Comment faire pour que dans la TextBox1, le format soit en nombre, sans décimale ?

Merci d'avance pour vos réponses.
 

Pièces jointes

Dernière édition:
Re : Trier les données par ordre croissant via UserForm

Bonjour JMR
Peut-être tout simplement en ajoutant un tri à la fin de ta commande valider.

With Sheets("donnees")
.UsedRange.Sort key1:=.Columns(1), Header:=xlYes
End With
Pour la textbox1, elle est saisie par l'utilisateur est-ce que tu veux que la saisie de décimale soit interdite??
 
Re : Trier les données par ordre croissant via UserForm

Bonjour JMR
Peut-être tout simplement en ajoutant un tri à la fin de ta commande valider.

With Sheets("donnees")
.UsedRange.Sort key1:=.Columns(1), Header:=xlYes
End With
Pour la textbox1, elle est saisie par l'utilisateur est-ce que tu veux que la saisie de décimale soit interdite??

Bonjour,

Merci pour la réponse.

En effet, je voudrais que la saisie de décimale soit interdite si possible.
 
Re : Trier les données par ordre croissant via UserForm

bonjour
je te propose un controle de saisie sur la texbox1 .

Private Sub TextBox1_Change()
If IsNumeric(TextBox1) = False Then
TextBox1 = ""
Exit Sub
End If
TextBox1 = Int(TextBox1)
End Sub
 
Re : Trier les données par ordre croissant via UserForm

bonjour JMR150 sousou

on peut egalement utiliser keypress

Code:
Private Sub TextBox1_KeyPress(ByVal K As MSForms.ReturnInteger)
  If Len(TextBox1) = 0 And InStr("123456789", Chr(K)) = 0 Then K = 0
  If Len(TextBox1) > 0 And InStr("0123456789", Chr(K)) = 0 Then K = 0
End Sub
 
- Navigue sans publicité
- Accède à Cléa, notre assistante IA experte Excel... et pas que...
- Profite de fonctionnalités exclusives
Ton soutien permet à Excel Downloads de rester 100% gratuit et de continuer à rassembler les passionnés d'Excel.
Je deviens Supporter XLD

Discussions similaires

Retour