我知道这已经引起了人们的注意,但我无法解决它。我有一个调用 sub 的按钮,在该 sub 中我想确保 numlock 始终处于打开状态。第一次,即如果numlock 关闭,它会打开它。如果它已经打开,单击按钮一次或两次会使数字锁定保持打开状态,但单击第三次会关闭数字锁定。再次单击可将其关闭。再次单击将其再次打开。所以每3次点击它就会关闭它。我不明白如何解决它。我有 Excel 2019 位和 Windows 10 64 位。这是代码:
Private Declare PtrSafe Function GetKeyState Lib "user32" (ByVal nVirtKey As Long) As Integer
Private Const kCapital = 20
Private Const kNumlock = 144
Public Function CapsLock() As Boolean
CapsLock = KeyState(kCapital)
End Function
Public Function NumLock() As Boolean
NumLock = KeyState(kNumlock)
End Function
Private Function KeyState(lKey As Long) As Boolean
KeyState = CBool(GetKeyState(lKey))
End Function
Public Sub ToggleNumlock(choice As Boolean)
Application.Volatile
If choice = True Then
If NumLock = False Then SendKeys "{NUMLOCK}", True
Else
If NumLock = True Then SendKeys "{NUMLOCK}", True
End If
End Sub
在按钮触发的子中,我有:
Application.SendKeys "{F2}"
就在我拥有之后
If NumLock = False Then
ToggleNumlock (True)
End If
会不会是 Sendkeys 引起了麻烦?因为我需要它,有解决方法吗?谢谢你。
更新我的代码:
ActiveSheet.Range(CurrentCell).Value = "="
ActiveSheet.Range(CurrentCell).Select
Application.SendKeys "{F2}", True
Application.SendKeys "=", True
Application.SendKeys "{F2}"
我删除了所有关于 numlock on off 等的代码,并尝试它至少现在可以在我的机器上工作:我只需按两次键。明天我会在我的办公室机器上检查这个。
2021 年 7 月 19 日更新在我的办公室(Windows 64 本地化意大利语,Excel 2010)我遇到了同样的数字锁定问题,它可以切换但数字键盘上的逗号也变成了一个点(在意大利,它是 3,14 而不是 3.14)。我放弃。感谢所有试图帮助我的人。MS必须真正修复sendkeys。