返回列表 上一主題 發帖

[發問] abc-8888 自動轉化 ABC-888...

[發問] abc-8888 自動轉化 ABC-888...

同一儲存格輸入車牌 abc-8888 希望能自動轉化 ABC-8888 之格式
例如在 E3儲存格輸入abc-8888 希望能自動轉化 ABC-8888
             E4儲存格輸入2050-sa   希望能自動轉化 2050-SA
我只想在 E3:E1002 儲存格內自動轉換大寫英文...
望請各位高手解惑

用公式 UPPER可以達成。

TOP

如果要完全自動。
參考你另一帖
身分證代碼
http://forum.twbts.com/thread-16089-1-1.html

TOP

詳看附件:
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2. If Application.Intersect([E3:E1002], Target) Is Nothing Then Exit Sub
  3. Application.EnableEvents = 0
  4. Target.Value = UCase(Target.Value)
  5. Application.EnableEvents = 1
  6. End Sub
複製代碼

zz.zip (13.34 KB)

TOP

以前問過一模一樣的需求, 只是身份證號換成車號,
又要問一次, 這又怎麼學得到東西呢???

TOP

感謝先進的指導

TOP

回復 4# ikboy
感謝先進指導
針對上述公式程式碼...
以圖為例 若 E3 輸入abc-8558

依公式程式碼 會進行英文小寫轉換大寫
若是想要用複製其他工作表之車牌號碼(k3:k20)
至 E3:E20 儲存格...
該程式碼無法一次自動轉換至大寫英文
需該如何重新編寫程式碼?

0609.jpg (82.05 KB)

0609.jpg

0609.rar (9.67 KB)

TOP

本帖最後由 准提部林 於 2020-6-9 11:11 編輯

回復 7# cypd

以下藍色字都要copy到


Dim CK%

Private Sub Worksheet_Change(ByVal Target As Range)
Dim xR As Range
With Target
     If .Columns.Count > 1 Or .Column <> 5 Then Exit Sub
     If CK > 0 Then Exit Sub
     On Error GoTo 999
     CK = 1
     For Each xR In .Cells
         If xR.Row < 3 Or xR.Value = "" Then GoTo 101
         xR.Value = UCase(xR.Value)
101: Next
End With
999: CK = 0
End Sub

TOP

回復 8# 准提部林
好神奇的語法...感恩
不明白儲存格用
1.輸入的方式
及用 2.複製貼上之方式
兩者間之英文小寫轉換大寫,差異大不同?
懇問程式碼中內的數字各代表甚麼意思?
If xR.Row < 3 Or xR.Value = "" Then GoTo 101
         xR.Value = UCase(xR.Value)
101: Next
End With
999: CK = 0

TOP

回復 9# cypd


不是一言兩語可說清,
先逐行去理解吧!
若連.row, .value, .column, .columns都不懂, 解釋了也沒用~~

試著將每行了解一下, 並做註解

CK 用來替代 Application.EnableEvents
避免"反覆觸動", 造成當機~~

ON ERROR GOTO 999
若程式執行錯誤中斷, 會直接去執行 999:CK=0
否則下次就不能產生CHANGE事件~~

TOP

        靜思自在 : 天上最美是星星,人生最美是溫情。
返回列表 上一主題