Affecter une note grâce à une inputbox - Excel VBA
Résolu
Naririne
Messages postés
106
Date d'inscription
Statut
Membre
Dernière intervention
-
Naririne Messages postés 106 Date d'inscription Statut Membre Dernière intervention -
Naririne Messages postés 106 Date d'inscription Statut Membre Dernière intervention -
Bonjour !
Pourriez-vous m'aider s'il vous plait ?
J'ai une liste d'étudiants (A1:A21) qui ont des notes chacun (B1:B21) ainsi que des appréciations (C1:C21). Deux problèmes :
- Il peut arriver qu'un étudiant n'ait pas de note.
- Il se peut qu'un étudiant ait une note de 150 ou autre (faute de frappe, la note doit être comprise entre 0 et 20)
Comment demander à l'utilisateur grâce à une InputBox de saisir une note quand la cellule est vide ? Et de saisir une note valide le cas échéant ?
Ci dessous le code que j'ai :
(Pour le moment, je n'ai qu'une MsgBox pour dire de saisir une note valide)
Merci d'avance pour votre aide !!
Peace !
Pourriez-vous m'aider s'il vous plait ?
J'ai une liste d'étudiants (A1:A21) qui ont des notes chacun (B1:B21) ainsi que des appréciations (C1:C21). Deux problèmes :
- Il peut arriver qu'un étudiant n'ait pas de note.
- Il se peut qu'un étudiant ait une note de 150 ou autre (faute de frappe, la note doit être comprise entre 0 et 20)
Comment demander à l'utilisateur grâce à une InputBox de saisir une note quand la cellule est vide ? Et de saisir une note valide le cas échéant ?
Ci dessous le code que j'ai :
(Pour le moment, je n'ai qu'une MsgBox pour dire de saisir une note valide)
Sub macro_appreciations Dim i As Long Dim note As Integer Dim app As String Dim cel As Range nbeleves = Range("A1048576").End(xlUp).Row - 1 For i = 1 To nbeleves note = Range("A1").Offset(i, 1).Value If note = 0 Then app = "Nul" ElseIf note >= 1 And note <= 5 Then app = "Très Insuffisant" ElseIf note >= 6 And note <= 9 Then app = "Insuffisant" ElseIf note >= 10 And note <= 15 Then app = "Bien" ElseIf note >= 16 And note <= 19 Then app = "Très Bien" ElseIf note = 20 Then app = "Excellent" Else MsgBox "Saisir une note valide" End If Range("A1").Offset(i, 2) = app Next i End Sub
Merci d'avance pour votre aide !!
Peace !
A voir également:
- Affecter une note grâce à une inputbox - Excel VBA
- Déplacer une colonne excel - Guide
- Liste déroulante excel - Guide
- Trier une colonne excel - Guide
- Word et excel gratuit - Guide
- Imprimer tableau excel sur une page - Guide
8 réponses
Bonjour,
Tu peux résoudre ton problème sans utiliser VBA !
une validation de données type liste avec tes notes de 0 à20 ce qui empêche des saisies farfelues
un tableau annexe facile à modifier avec en colonnes les seuils 0,5 etc. et à coté l'appréciation...
une RECHERCHEV dans la colonne C.
toujours penser excel avant de penser VBA ! ;o)
Tu peux résoudre ton problème sans utiliser VBA !
une validation de données type liste avec tes notes de 0 à20 ce qui empêche des saisies farfelues
un tableau annexe facile à modifier avec en colonnes les seuils 0,5 etc. et à coté l'appréciation...
une RECHERCHEV dans la colonne C.
toujours penser excel avant de penser VBA ! ;o)
Bonjour le fil, bonjour le forum,
Une proposition VBA :
Une proposition VBA :
Sub macro_appreciations()
Dim NE As Integer 'déclare la variable NE (Nombre d'Élèves)
Dim I As Integer 'déclare la variable I (Incrément)
Dim TC As Variant 'déclare la variable TC (Tableau de cellules)
Dim BN As Variant 'déclare la variable BN (Boîte Note)
Dim note As Integer 'déclare la variable note
NE = Cells(Application.Rows.Count, 1).End(xlUp).Row - 1 'définit le nombre d'élèves (pourquoi -1 ?)
TC = Range("A1:C" & NE) 'définit le tableau de cellules TC
For I = 2 To UBound(TC, 1) 'boucle sur toutes les ligne du tableau TC (en partant de la seconde)
'condition 1 : si la valeur en colonne 1 de la ligne est vide ou si elle est inférieure à 0 ou supérieure à 20
If TC(I, 2) = "" Or TC(I, 2) < 0 Or TC(I, 2) > 20 Then
Cells(I, 2).Interior.ColorIndex = 3 'colore la cellule de rouge
NV: 'étiquette (Non Valide)
BN = Application.InputBox("Veuillez saisir une note valide !", Type:=1) 'déffinit la boîte d'entrée BN
If BN = False Then 'condition 2 : si bouton "Annuler" dans la boîte d'entrée BE
'si "Non" au message retourne à la boîte d'entrée (via l'étiquette NV), si "Oui" au message passe à la note suivante (via l'étiquette "suite")
If MsgBox("L'élève " & Cells(I, 1).Value & " n'est pas noté ! Voulez-vous continuer ?", vbYesNo, "ATTENTION") = vbNo Then GoTo NV Else GoTo suite
End If 'fin de la condition 2
If BN < 0 Or BN > 20 Then MsgBox "Note non valide !": GoTo NV 'condition 3 : si la note n'est pas valide, retoure à la boîte d'entrée (via l'étiquette "NV")
Cells(I, 2).Value = BN 'place la note dans la cellule
Cells(I, 2).Interior.ColorIndex = xlNone 'supprime la couleur rouge de la cellule
End If 'fin de la condition 3
note = Cells(I, 2).Value 'définit la variable note
Select Case note 'action en fonction de la note
Case 0 'cas zéro
Cells(I, 3).Value = "Nul" 'appréciation dans la cellule en colonne 3
Case 1 To 5 'de 1 a 5
Cells(I, 3).Value = "Très Insuffisant" 'appréciation dans la cellule en colonne 3
Case 6 To 9 'de 6 à 9
Cells(I, 3).Value = "Insuffisant" 'appréciation dans la cellule en colonne 3
Case 10 To 15 'de 10 à 15
Cells(I, 3).Value = "Bien" 'appréciation dans la cellule en colonne 3
Case 16 To 19 'de 19 à 19
Cells(I, 3).Value = "Très Bien" 'appréciation dans la cellule en colonne 3
Case 20 'cas 20
Cells(I, 3).Value = "Excellent" 'appréciation dans la cellule en colonne 3
End Select 'fin de l'action en fonction de la note
suite: 'étiquette
Next I 'prochaine ligne du tableau TC
End Sub
en attendant
Nota pour ton prof : les goto sont autorisés et utilisés dans la gestion des erreurs
Michel
Nota pour ton prof : les goto sont autorisés et utilisés dans la gestion des erreurs
Option Explicit '---- Sub macro_appreciations() Dim nbeleves As Byte Dim i As Byte Dim note As Single nbeleves = Range("A1048576").End(xlUp).Row For i = 1 To nbeleves On Error GoTo erreur 1: note = InputBox(prompt:="note de " & Cells(i, "A") & " ? ") Select Case note Case Is = 0 Cells(i, "C") = "nul" Case Is <= 5 Cells(i, "C") = "très insuffisant" Case Is <= 9 Cells(i, "C") = "insuffisant" Case Is <= 15 Cells(i, "C") = "bien" Case Is <= 19 Cells(i, "C") = "très bien" Case Is <= 20 Cells(i, "C") = "excellent" Case Else MsgBox "saisir une note entre 0 et 20", vbCritical GoTo 1 End Select Cells(i,"B")=note Next i Exit Sub erreur: MsgBox "saisie d'un texte non valable", vbCritical Resume 1 End Sub
Michel
Salut,
Tu as, à côté de la balise code <> une liste de choix te permettant de choisir ton langage de programmation. Sélectionne Basic.
Les balises sont :
<code basic></code>
Le mode d'emploi (au cas ou) est ICI.
Cordialement,
Pijaku
Tu as, à côté de la balise code <> une liste de choix te permettant de choisir ton langage de programmation. Sélectionne Basic.
Les balises sont :
<code basic></code>
Le mode d'emploi (au cas ou) est ICI.
Cordialement,
Pijaku
Bonjour Michel_M
Merci d'avoir répondu à mes questions !
Oui on peut le résoudre facilement par Excel, je l'ai déjà fait :)
Mais dans le cadre d'un cours à la fac, on nous demande de passer par du VBA pour résoudre ce problème. La plus grosse partie du code est faite. Il ne me reste plus qu'à travailler sur les petits pièges. Et c'est là où je patine :(
Merci d'avoir répondu à mes questions !
Oui on peut le résoudre facilement par Excel, je l'ai déjà fait :)
Mais dans le cadre d'un cours à la fac, on nous demande de passer par du VBA pour résoudre ce problème. La plus grosse partie du code est faite. Il ne me reste plus qu'à travailler sur les petits pièges. Et c'est là où je patine :(
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour tout le monde,
J'arrive après la guerre donc c'est beaucoup plus simple...
Une solution, honteusement pompée sur celle de Michel ;-), par fonction avec des tests complémentaires (séparateur décimal et boucle tant que note incorrecte) :
ps : salut Michel, comment va?
🎼 Cordialement,
Franck 🎶
J'arrive après la guerre donc c'est beaucoup plus simple...
Une solution, honteusement pompée sur celle de Michel ;-), par fonction avec des tests complémentaires (séparateur décimal et boucle tant que note incorrecte) :
Option Explicit '---- Sub macro_appreciations() Dim nbeleves As Byte Dim i As Byte Dim Note As Single Dim Quoi As String, Par As String Par = Application.International(xlDecimalSeparator) Quoi = IIf(Par = ",", ".", ",") nbeleves = Range("A1048576").End(xlUp).Row For i = 1 To nbeleves Do Note = Replace(InputBox(prompt:="note de " & Cells(i, "A") & " ? "), Quoi, Par) If Note < 0 Or Note > 20 Then MsgBox "saisir une note entre 0 et 20", vbCritical Loop While Note < 0 Or Note > 20 Cells(i, "B") = Note Cells(i, "C") = Appreciation(Note) Next i End Sub Function Appreciation(sgNote As Single) As String Select Case sgNote Case Is = 0 Appreciation = "nul" Case Is <= 5 Appreciation = "très insuffisant" Case Is <= 9 Appreciation = "insuffisant" Case Is <= 15 Appreciation = "bien" Case Is <= 19 Appreciation = "très bien" Case Is <= 20 Appreciation = "excellent" Case Else Appreciation = "Erreur inconnue" End Select End Function
ps : salut Michel, comment va?
🎼 Cordialement,
Franck 🎶