Première lettre d'un mot en majuscule

Résolu/Fermé
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 - 7 juin 2021 à 22:11
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 - 9 juin 2021 à 22:53
Bonjour,

Une question simple (j'espère) : est-il possible d'écrire un prénom en minuscule dans une cellule et que, quand on quitte la cellule, la première lettre du prénom passe en majuscule.

J'aimerai que ce soit faisable sans saisir toute une liste de prénoms et revenir ensuite faire cette opération par une macro.
Merci d'avance.
A voir également:

7 réponses

ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023 478
7 juin 2021 à 22:18
Bonjour,

Voici une solution possible à placer dans une feuille :

Private Sub Worksheet_Change(ByVal Target As Range)
Dim text As String
text = Target.Value
Target.Value = UCase(Left(text, 1)) + Mid(text, 2, Len(text))
End Sub


Source: https://stackoverflow.com/questions/59113711/vba-how-to-use-vbpropercase-to-capitalize-the-first-letter-but-keep-every-other
1
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 1
Modifié le 9 juin 2021 à 22:57
Bonjour,
Cette solution me convient parfaitement et répond à mon besoin.
Par contre, ça ne fonctionne pas avec les prénoms composés, mais sur 99 saisies, il n'y en a que 2, donc négligeable.
Et je n'arrive pas à utiliser la solution de michel_m qui répondait à la question de PapyLuc.
Merci à tous pour vos solutions et vos remarques qui m'ont bien aidées.
0
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
Modifié le 8 juin 2021 à 08:25
Bonjour

Tout simplement :-)


1
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
Modifié le 8 juin 2021 à 15:02
errata
0
PapyLuc51 Messages postés 4392 Date d'inscription dimanche 3 mai 2009 Statut Membre Dernière intervention 6 novembre 2024 1 445
8 juin 2021 à 11:22
Salut à tous

J'ai essayé ce code qui fonctionne très bien sur la 1ere lettre.

Qu'en est-il lorsqu'il s'agit d'un prénom composé? rajouter un bout de code (moi, je n'y connais rien)

Sinon il existe la fonction NOMPROPRE() qui évite de faire une liste.

cordialement
1
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
8 juin 2021 à 15:43
Salut Papy
avec plusieurs prénoms composés
Option Explicit
'---------------------------------------------------
Private Sub Worksheet_Change(ByVal Target As Range)
Dim Separ, Prenom As String, Cptr As Byte

If Not Intersect(Target, Columns("B")) Is Nothing Then
Application.EnableEvents = False 'interdit le réamorcage de la macro
Separ = Split(Target, "-")
For Cptr = 0 To UBound(Separ)
Prenom = Prenom & Separ(Cptr)
If Cptr < UBound(Separ) Then Prenom = Prenom & "-"
Next
Target = Application.Proper(Prenom)
End If
Application.EnableEvents = True
End Sub
'---------------------------------------------------------------------------------------------------------------------------------------------------
Sub sos_events()
'Au cas où on sort de la macro avant enableevents=true,Les macros ne peuvent plus fonction dans Excel!!!!!
'cette macro réhabilite le fonctionnement: A CONSERVER PRECIEUSEMENT
Application.EnableEvents = True
End Sub
0
michel_m Messages postés 16603 Date d'inscription lundi 12 septembre 2005 Statut Contributeur Dernière intervention 16 décembre 2023 3 310
8 juin 2021 à 15:01
Lorsque tu as selectionné "worksheet" dans la fen^tre du milieu, sélectionne dans la fen^tre (déclarations) :
l'option "Change"

1

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

Posez votre question
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 1
7 juin 2021 à 22:24
Bonjour Ozone,
j'ai créé cette macro, mais pas de résultat.
j'ai loupé quelque chose ?
0
ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023 478
7 juin 2021 à 22:32
Cette macro est-elle bien placée dans la feuille concernée ? (Souvent l'onglet Feuil1)
0
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 1 > ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023
7 juin 2021 à 22:36
elle est bien placée, mais j'ai ce message : erreur de compilation : nom ambigu détecté : Worksheet _Change
0
Raymond PENTIER Messages postés 58719 Date d'inscription lundi 13 août 2007 Statut Contributeur Dernière intervention 7 novembre 2024 17 233
7 juin 2021 à 23:39
Bonjour.

Ce que tu veux faire, c'est une fonctionnalité des traitements de texte ; pas des tableurs.
Par conséquent tu dois copier-coller ta liste dans Word, utiliser l'outil "Modifier la casse", et de nouveau faire un copier-coller, mais cette fois de Word vers Excel.

Le mieux, bien entendu, est de saisir correctement les prénoms dès le départ !
0
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 1
8 juin 2021 à 11:27
Bonjour,
Je vous remercie tous pour vos messages, mais quand j'essaie la solution de Michel, j'ai à nouveau ce message :
erreur de compilation : nom ambigu détecté : Worksheet _Change

Je pense faire correctement mais ....
0
ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023 478
8 juin 2021 à 13:40
Tu dois déjà avoir une instruction Worksheet_change présente dans la feuille.
Vois pour les regrouper
0
gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024 1 > ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023
8 juin 2021 à 19:03
Bonjour,
je me suis absenté un peu, je reviens.
Effectivement, j'ai déjà une instruction Worksheet...

Qui est la suivante :
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Column = 6 And Target.Value = 0 Then
ActiveSheet.Unprotect "w"
Cells(Target.Row, 1).Resize(, 8).Locked = True
ActiveSheet.Protect "w"
End If
End Sub

Et bien entendu, je ne sais pas les regrouper !
Encore un peu d'aide ?
Merci
0
ozone_ Messages postés 1518 Date d'inscription lundi 13 juillet 2009 Statut Membre Dernière intervention 2 juin 2023 478 > gigipong Messages postés 118 Date d'inscription samedi 27 avril 2013 Statut Membre Dernière intervention 26 mai 2024
8 juin 2021 à 20:11
He bien je propose cette solution pour tout regrouper :

Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Column = 6 And Target.Value = 0 Then
ActiveSheet.Unprotect "w"
Cells(Target.Row, 1).Resize(, 8).Locked = True
ActiveSheet.Protect "w"
End If
ActiveCell = Application.proper(ActiveCell)
End Sub


Je reprends la solution de michel_m car bien plus simple que ma proposition du début.
Et pour info, l'instruction peut être mise avant ou après la condition déjà présente (If/End If)
0
PapyLuc51 Messages postés 4392 Date d'inscription dimanche 3 mai 2009 Statut Membre Dernière intervention 6 novembre 2024 1 445
8 juin 2021 à 13:53
J'ai procédé comme ceci pour entrer le code

clic droit sur l'onglet de la feuille / visualiser le code / coller dans la fenêtre qui s'ouvre

Cordialement
0