Bỏ qua nội dung chính

Làm cách nào để chèn khoảng trắng trước chữ in hoa trong excel?

Giả sử bạn có một danh sách các chuỗi văn bản mà tất cả các khoảng cách giữa các từ đều bị xóa vô tình, như sau: ChènHàng trốngGiữaDữ liệuvà bây giờ bạn muốn thêm khoảng trắng trước mỗi chữ cái bằng chữ in hoa để phân tách các từ dưới dạng Chèn hàng trống giữa dữ liệu. Làm cách nào bạn có thể thêm dấu cách vào trước các chữ cái viết hoa một cách nhanh chóng thay vì nhập từng dấu cách một trong Excel?


Chèn dấu cách trước các chữ cái viết hoa với Hàm do Người dùng Xác định

Rất tiếc, không có cách nào trực tiếp để bạn thêm khoảng trắng trước các chữ cái viết hoa trong Excel, nhưng bạn có thể tạo Hàm do người dùng xác định để giải quyết công việc này.

1. Kích hoạt trang tính của bạn có chứa các chuỗi văn bản bạn muốn thêm khoảng trắng.

2. Giữ ALT + F11 phím để mở Cửa sổ Microsoft Visual Basic for Applications.

3. Nhấp chuột Chèn > Mô-đunvà dán mã sau vào Cửa sổ mô-đun.

Mã VBA: Chèn khoảng trắng trước chữ in hoa

Function AddSpaces(pValue As String) As String
'Update 20140723
Dim xOut As String
xOut = VBA.Left(pValue, 1)
For i = 2 To VBA.Len(pValue)
   xAsc = VBA.Asc(VBA.Mid(pValue, i, 1))
   If xAsc >= 65 And xAsc <= 90 Then
      xOut = xOut & " " & VBA.Mid(pValue, i, 1)
   Else
      xOut = xOut & VBA.Mid(pValue, i, 1)
   End If
Next
AddSpaces = xOut
End Function

4. Sau đó, lưu và đóng mã này, quay lại trang tính và nhập công thức này = addspaces (A1) vào một ô trống bên cạnh dữ liệu của bạn, hãy xem ảnh chụp màn hình:
doc-add-space-before-hoa-1

5. Và sau đó kéo chốt điền trên phạm vi mà bạn muốn chứa công thức này, bạn sẽ nhận được các khoảng trắng được chèn vào trước mỗi chữ cái viết hoa của bạn.
doc-add-space-before-hoa-1

Dễ dàng loại bỏ khoảng trắng đầu / cuối / thừa trong ô

Kutools cho Excel's Xóa dấu cách tiện ích cho phép người dùng Excel dễ dàng loại bỏ tất cả khoảng trắng đầu, khoảng trắng cuối, khoảng trắng thừa hoặc tất cả khoảng trắng khỏi các ô đã chọn một cách nhanh chóng.


ad bỏ khoảng trống 1

Chèn dấu cách trước các chữ cái viết hoa bằng mã VBA

Đây là một mã VBA khác có thể giúp bạn, vui lòng làm như sau:

1. Giữ ALT + F11 phím để mở Cửa sổ Microsoft Visual Basic for Applications.

2. Nhấp chuột Chèn > Mô-đunvà dán mã sau vào Cửa sổ mô-đun.

Mã VBA: Chèn khoảng trắng trước chữ in hoa

Sub AddSpacesRange()
'Update 20140723
Dim Rng As Range
Dim WorkRng As Range
Dim xOut As String
Dim xValue As String
On Error Resume Next
xTitleId = "KutoolsforExcel"
Set WorkRng = Application.Selection
Set WorkRng = Application.InputBox("Range", xTitleId, WorkRng.Address, Type:=8)
Application.ScreenUpdating = False
For Each Rng In WorkRng
    xValue = Rng.Value
    xOut = VBA.Left(xValue, 1)
    For i = 2 To VBA.Len(xValue)
       xAsc = VBA.Asc(VBA.Mid(xValue, i, 1))
       If xAsc >= 65 And xAsc <= 90 Then
          xOut = xOut & " " & VBA.Mid(xValue, i, 1)
       Else
          xOut = xOut & VBA.Mid(xValue, i, 1)
       End If
    Next
    Rng.Value = xOut
Next
Application.ScreenUpdating = True
End Sub

3. Sau đó nhấn F5 để thực thi mã này, một hộp nhắc sẽ bật ra cho phép bạn chọn phạm vi dữ liệu mà bạn muốn sử dụng.
doc-add-space-before-hoa-1

4. Và sau đó nhấp vào OK để đóng hộp nhắc này, các khoảng trắng đã được chèn trước các chữ cái viết hoa cùng một lúc, xem ảnh chụp màn hình:
doc-add-space-before-hoa-1


Chèn dấu cách trước mỗi chữ cái viết hoa với Kutools cho Excel

Kutools cho Excel's thêm văn bản tiện ích có thể giúp bạn bỏ qua macro VBA và chèn khoảng trắng trước mọi chữ cái viết hoa một cách dễ dàng trong Excel.

Kutools cho Excel - Được đóng gói với hơn 300 công cụ cần thiết cho Excel. Tận hưởng bản dùng thử MIỄN PHÍ 30 ngày đầy đủ tính năng mà không cần thẻ tín dụng! Tải ngay!

1. Chọn phạm vi mà bạn sẽ chèn khoảng trắng trước chữ in hoa và nhấp vào Kutools > bản văn > thêm văn bản. Xem ảnh chụp màn hình:

2. Trong hộp thoại Thêm Văn bản đang mở, hãy nhập khoảng trắng vào bản văn hộp, kiểm tra Chỉ thêm vào tùy chọn và chọn Chữ cái đầu tiên là chữ hoa từ Chỉ thêm vào danh sách thả xuống.

3. Nhấn vào Ok để chèn khoảng trắng trước mỗi chữ hoa như ảnh chụp màn hình sau:
doc thêm dấu cách trước chữ hoa 7

Kutools cho Excel - Supercharge Excel với hơn 300 công cụ thiết yếu. Tận hưởng bản dùng thử MIỄN PHÍ 30 ngày đầy đủ tính năng mà không cần thẻ tín dụng! Get It Now

Chú ý: Phương thức này cũng sẽ thêm khoảng trắng ở đầu ô nếu chữ cái đầu tiên là viết hoa. Bạn có thể áp dụng Kutools > bản văn > Xóa dấu cách để xóa tất cả các khoảng trắng ở đầu khỏi các ô đã chọn.


Bài viết liên quan:

Công cụ năng suất văn phòng tốt nhất

🤖 Trợ lý AI của Kutools: Cách mạng hóa việc phân tích dữ liệu dựa trên: Thực thi thông minh   |  Tạo mã  |  Tạo công thức tùy chỉnh  |  Phân tích dữ liệu và tạo biểu đồ  |  Gọi các hàm Kutools...
Các tính năng phổ biến: Tìm, đánh dấu hoặc xác định các bản sao   |  Xóa hàng trống   |  Kết hợp các cột hoặc ô mà không làm mất dữ liệu   |   Vòng không có công thức hữu ích. Cảm ơn !
Siêu tra cứu: Nhiều tiêu chí VLookup    VLookup Nhiều Giá Trị  |   VLookup trên nhiều trang tính   |   Tra cứu mờ ....
Danh sách thả xuống nâng cao: Tạo nhanh danh sách thả xuống   |  Danh sách thả xuống phụ thuộc   |  Danh sách thả xuống nhiều lựa chọn ....
Trình quản lý cột: Thêm một số cột cụ thể  |  Di chuyển cột  |  Chuyển đổi trạng thái hiển thị của các cột ẩn  |  So sánh dãy và cột hữu ích. Cảm ơn !
Các tính năng nổi bật: Tiêu điểm lưới   |  Chế độ xem thiết kế   |   Thanh công thức lớn    Trình quản lý sổ làm việc & trang tính   |  Thư viện tài nguyên (Văn bản tự động)   |  Bảng chọn ngày   |  Kết hợp các bảng tính   |  Mã hóa/Giải mã ô    Gửi email theo danh sách   |  Siêu lọc   |   Bộ lọc đặc biệt (lọc in đậm/nghiêng/gạch ngang...) ...
15 bộ công cụ hàng đầu12 bản văn CÔNG CỤ (thêm văn bản, Xóa ký tự,...)   |   50 + Biểu đồ Các loại (Biểu đồ Gantt,...)   |   40+ Thực tế Công thức (Tính tuổi dựa trên ngày sinh,...)   |   19 chèn CÔNG CỤ (Chèn mã QR, Chèn ảnh từ đường dẫn,...)   |   12 Chuyển đổi CÔNG CỤ (Số thành từ, Chuyển đổi tiền tệ,...)   |   7 Hợp nhất & Tách CÔNG CỤ (Các hàng kết hợp nâng cao, Chia ô,...)   |   ... và nhiều hơn nữa

Nâng cao kỹ năng Excel của bạn với Kutools for Excel và trải nghiệm hiệu quả hơn bao giờ hết. Kutools for Excel cung cấp hơn 300 tính năng nâng cao để tăng năng suất và tiết kiệm thời gian.  Bấm vào đây để có được tính năng bạn cần nhất...

Mô tả


Tab Office mang lại giao diện Tab cho Office và giúp công việc của bạn trở nên dễ dàng hơn nhiều

  • Cho phép chỉnh sửa và đọc theo thẻ trong Word, Excel, PowerPoint, Publisher, Access, Visio và Project.
  • Mở và tạo nhiều tài liệu trong các tab mới của cùng một cửa sổ, thay vì trong các cửa sổ mới.
  • Tăng 50% năng suất của bạn và giảm hàng trăm cú nhấp chuột cho bạn mỗi ngày!
Comments (9)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
This function handles two problems that the given solution doesn't cover:
1. non-English text (with diacritical marks)
2. successive capitals that should not have spaces after them

` Private Function AddSpaces(sText As String)As String
' Inserts a space immediately before a capital letter, except when successive characters are each capitalized.
' Last Updated: 2022-07-04
'
Dim sRet As String, i As Integer, sChar As String, bPrevWasUCase As Boolean

sRet = Left(sText, 1)
For i = 2 To Len(sText)
sChar = Mid(sText, i, 1)
If sChar = UCase(sChar) And Not bPrevWasUCase Then
sRet = sRet & " " & sChar
bPrevWasUCase = True
Else
sRet = sRet & sChar
bPrevWasUCase = False
End If
Next i

AddSpaces= sRet
End Function`
This comment was minimized by the moderator on the site
Hello friend,

Thanks for your share. I tried your VBA code, but it doesn't work. Our VBA code can handle the non-english text. I have test the french text and spaces are successfully inserted before the capital letters.

Sincerely,
Mandy
This comment was minimized by the moderator on the site
Hello

First thanks a lot for your code example and the explanations. It works very well for my case.

I just have 1 Problem, some of the Strings contain words like URL, which should not be seperated.
Do you see a way to except for example "URL" from adding spaces?

Would be very nice if you can help. I tried already a while, but i dont know how to solve this..


Best regards
luca
This comment was minimized by the moderator on the site
hi wanna ask you if you found solution for you case, if you found solution please provide me with that
This comment was minimized by the moderator on the site
Hi,
Thanks for your comment and advice. I have sent your suggestion to the Kutools project team, I’m sure they’ll improve it soon.
This comment was minimized by the moderator on the site
Found a solution?
This comment was minimized by the moderator on the site
Hi there, your code works fantastic. Do you know how to adapt code 20140723 to work on multiple sheets? I would like to add spaces between capital letters throughout the entire workbook. Thanks!
This comment was minimized by the moderator on the site
i need a help in excel i want to find Uppercase in a cell. for example: Sagar Paul MBA 16:04 i want MBA to be highlighted
This comment was minimized by the moderator on the site
I hope you can see it and give it a trial. Sub Test() Dim Rg As Range, xCell As Range Dim i As Long Dim xChar As String Set Rg = Application.Selection For Each xCell In Rg For i = 1 To xCell.Characters.Count xChar = xCell.Characters(i, 1).Text If Asc(xChar) > 64 And Asc(xChar) < 91 Then xCell.Characters(i, 1).Font.Color = vbRed End If Next Next End Sub
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations