0

我知道这已经引起了人们的注意,但我无法解决它。我有一个调用 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。

4

1 回答 1

2

根据这篇文章,您可以使用以下代码打开 Num Lock

Option Explicit
'https://www.vbarchiv.net/tipps/details.php?id=563

Private Declare PtrSafe Function GetKeyState Lib "user32" (ByVal nVirtKey As Long) As Integer


Private Declare Sub keybd_event Lib "user32" ( _
    ByVal bVk As Byte, _
    ByVal bScan As Byte, _
    ByVal dwFlags As Long, _
    ByVal dwExtraInfo As Long)
 
Private Const VK_NUMLOCK = &H90
Private Const KEYEVENTF_KEYUP = &H2

Sub pressNumLock()
    ' press NUM-Lock drücken
    ' first key down and then key-up
    keybd_event VK_NUMLOCK, 1, 0, 0
    keybd_event VK_NUMLOCK, 1, KEYEVENTF_KEYUP, 0
End Sub

Sub NumLockOn()
    ' activate NUM-Lock (in case it is not activated)
    If Not (GetKeyState(vbKeyNumlock) = 1) Then
        pressNumLock
    End If
End Sub
于 2021-07-18T13:47:50.900 回答