Première lettre d'un mot en majuscule

Résolu
gigipong Messages postés 118 Date d'inscription   Statut Membre Dernière intervention   -  
gigipong Messages postés 118 Date d'inscription   Statut Membre Dernière intervention   -
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   Statut Membre Dernière intervention   478
 
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   Statut Membre Dernière intervention   1
 
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 16602 Date d'inscription   Statut Contributeur Dernière intervention   3 314
 
Bonjour

Tout simplement :-)


1
michel_m Messages postés 16602 Date d'inscription   Statut Contributeur Dernière intervention   3 314
 
errata
0
PapyLuc51 Messages postés 4519 Date d'inscription   Statut Membre Dernière intervention   1 486
 
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 16602 Date d'inscription   Statut Contributeur Dernière intervention   3 314
 
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 16602 Date d'inscription   Statut Contributeur Dernière intervention   3 314
 
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   Statut Membre Dernière intervention   1
 
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   Statut Membre Dernière intervention   478
 
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   Statut Membre Dernière intervention   1 > ozone_ Messages postés 1518 Date d'inscription   Statut Membre Dernière intervention  
 
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 58991 Date d'inscription   Statut Contributeur Dernière intervention   17 356
 
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   Statut Membre Dernière intervention   1
 
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   Statut Membre Dernière intervention   478
 
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   Statut Membre Dernière intervention   1 > ozone_ Messages postés 1518 Date d'inscription   Statut Membre Dernière intervention  
 
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   Statut Membre Dernière intervention   478 > gigipong Messages postés 118 Date d'inscription   Statut Membre Dernière intervention  
 
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 4519 Date d'inscription   Statut Membre Dernière intervention   1 486
 
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