我正在创建一个用户表单来输入地址数据。我有一个地址名称的文本框,用于选择道路,街道等的组合框,以及用于奇数的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