我正在創建一個用戶表單來輸入地址數據。我有一個地址名稱的文本框,用於選擇道路,街道等的組合框,以及用於奇數的4個數字框以及來自和來自的evens。使用If語句清除單元格
我得到的問題是讓VBA清除「to」框的內容,如果數字已經輸入到它們中,但用戶將它們從「框」更改爲「to」框之後的更多值。
這裏是我目前擁有的代碼:
Private Sub txtstreet_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
Select Case KeyAscii
Case 65 To 90
Case 97 To 122
Case 32
Case 127
Case Else
KeyAscii = 0
End Select
End Sub
Private Sub UserForm_Initialize()
roaddesciptor.List = Array("ROAD", "STREET", "WAY", "AVENUE", "DRIVE", "GROVE", "LANE", "GARDENS", "PLACE", "CRESENT", "CLOSE", "SQUARE", "HILL", "CIRCUS", "MEWS", "VALE", "RISE", "ROW", "MEAD", "WHARF")
roaddesciptor.ListIndex = 0
End Sub
Private Sub txtaddoddfrom_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
Select Case KeyAscii
Case 48 To 57
Case Else
KeyAscii = 0
End Select
End Sub
Private Sub txtaddoddfrom_AfterUpdate()
If txtaddoddfrom.Value < txtaddoddto.Value Or txtaddoddto = "" And txtaddoddfrom.Value Mod 2 = 1 Then Exit Sub
If txtaddoddfrom.Value Mod 2 <> 1 Or txtaddoddfrom.Value > txtaddoddto.Value Then txtaddoddfrom = ""
'Else: txtaddoddfrom = ""
End Sub
Private Sub txtaddoddto_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
Select Case KeyAscii
Case 48 To 57
Case Else
KeyAscii = 0
End Select
End Sub
Private Sub txtaddoddto_AfterUpdate()
If txtaddoddto.Value Mod 2 = 1 And txtaddoddto.Value >= txtaddoddfrom.Value Then Exit Sub
If txtaddoddto.Value Mod 2 <> 1 Or txtaddoddto.Value < txtaddoddfrom.Value Then txtaddoddto = ""
End Sub
Private Sub txtaddevenfrom_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
Select Case KeyAscii
Case 48 To 57
Case Else
KeyAscii = 0
End Select
End Sub
Private Sub txtaddevenfrom_AfterUpdate()
If txtaddevenfrom.Value < txtaddevento.Value Or txtaddevento = 0 And txtaddevenfrom.Value Mod 2 <> 1 Then Exit Sub
If txtaddevenfrom.Value Mod 2 = 1 Or txtaddevenfrom.Value > txtaddevento.Value Then txtaddevenfrom = ""
End Sub
Private Sub txtaddevento_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
Select Case KeyAscii
Case 48 To 57
Case Else
KeyAscii = 0
End Select
End Sub
Private Sub txtaddevento_AfterUpdate()
If txtaddevento.Value Mod 2 <> 1 And txtaddevento.Value >= txtaddevenfrom.Value Then Exit Sub
If txtaddevento.Value Mod 2 = 1 Or txtaddevento.Value < txtaddevenfrom.Value Then txtaddevento = ""
End Sub
您可以使用'If Not IsNumeric(Chr(KeyAscii))'然後KeyAscii = 0'來檢查數字輸入,從而縮短代碼。 .....也可以使用這種類型的語句來使代碼更清晰:Case Asc(「a」)To Asc(「z」)'......'case 127'行似乎被誤包含 – jsotola