Capitalize first letter of first word only

sharky12345

Well-known Member
Joined
Aug 5, 2010
Messages
3,418
Office Version
  1. 2016
Platform
  1. Windows
Is there a way I can capitalize the first letter of the first word only in a Userform Textbox, rather than every word?

Better still, how about what I would call true propercase, where the first word of each sentence is capitalized, rather than the usual propercase which in my view is not accurate because it capitalizes every word.
 

Excel Facts

Copy a format multiple times
Select a formatted range. Double-click the Format Painter (left side of Home tab). You can paste formatting multiple times. Esc to stop
? When I use Proper() it does exactly what you want? Capital letter when new sentence.
 
Upvote 0
Well this capitalizes every word;

Code:
txtquestion.Value = StrConv(txtquestion.Value, vbProperCase)
 
Upvote 0
=Proper()
Capitalises the 1st character of each word.
Code:
[TABLE="width: 273"]
<tbody>[TR]
[TD]where the first word of each sentence is capitalized,[/TD]
[/TR]
[TR]
[TD]Where The First Word Of Each Sentence Is Capitalized,[/TD]
[/TR]
</tbody>[/TABLE]
 
Upvote 0
I get a compile error with this - what am I doing wrong?

Code:
txtquestion.Value = Proper()

Just realised that the previous post was just confirming what I had stated earlier.........
 
Upvote 0
Ok, on my computer it doesn't, perhaps a regional setting then. Sorry
 
Upvote 0
@sharky12345

First off, you are talking about "sentence" case, not "proper" case and VB code... second, gaz_chops was giving you a worksheet function solution, so the two of you are not talking about the same thing. There is no native sentence case function in either the worksheet functions or VB's functions, so we have to write one. Here is my idea for such a function (which can be called by other VB code or used as a UDF directly on a worksheet)...

Code:
Function SentenceCase(ByVal S As String) As String
  Dim X As Long, Z As Long, Paragraphs() As String, Sentences() As String
  Paragraphs = Split(S, vbLf)
  For X = 0 To UBound(Paragraphs)
    Sentences = Split(Paragraphs(X), ". ")
    For Z = 0 To UBound(Sentences)
      Sentences(Z) = UCase(Left(Sentences(Z), 1)) & LCase(Mid(Sentences(Z), 2))
    Next
    Paragraphs(X) = Join(Sentences, ". ")
  Next
  SentenceCase = Join(Paragraphs, vbLf)
End Function

For your needs, just pass it the contents of the TextBox and assign wherever you need to. For example, this CommandButton event code would change TextBox1's entry by the user into sentence case directly within TextBox1...

Code:
Private Sub CommandButton1_Click()
  TextBox1.Text = SentenceCase(TextBox1.Text)
End Sub
 
Upvote 0

Forum statistics

Threads
1,220,951
Messages
6,157,030
Members
451,392
Latest member
malcv

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top