首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在证明一段时间后执行Sub?

在证明一段时间后执行Sub?
EN

Stack Overflow用户
提问于 2017-06-03 09:35:13
回答 1查看 744关注 0票数 0

我正在尝试在UserForm打开后的某一段时间后执行Sub。访问启动后立即打开UserForm。有什么替代Application.OnTime的方法吗?因为它不适用于Access,而且似乎只适用于Excel。

这就是我的工作。

代码语言:javascript
复制
Private Sub UserForm_Activate()
Set objWSHShell = CreateObject("WScript.Shell")
DesktopDir = objWSHShell.SpecialFolders("Desktop") & "\"
InstallDir = Left(DesktopDir, 3) & "VICI"
VICIMxDir = InstallDir & "\VICI Mx.txt"
VICIFmDir = InstallDir & "\VICI Fm.txt"
VICIAnalyticsDir = InstallDir & "\VICI Analytics.txt"
With ListBox_Status
    If FSO.FileExists(VICIMxDir) = True Then 'Both exist
        .Column(1, 0) = "Ready"
    Else
        .Column(1, 0) = "Not Found"
    End If
    If FSO.FileExists(VICIFmDir) = True Then
        .Column(1, 1) = "Ready"
    Else
        .Column(1, 1) = "Not Found"
    End If
    If FSO.FileExists(VICIAnalyticsDir) = True Then
        .Column(1, 2) = "Ready"
    Else
        .Column(1, 2) = "Not Found"
    End If
.Column(1, 3) = Environ("UserName")
End With
Application.OnTime Now + TimeValue("00:00:10"), "DB_BackUP"
Application.OnTime Now + TimeValue("00:00:20"), "RmvDBBackup"
End Sub
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-03 13:40:43

您可以使用Application.Wait

代码语言:javascript
复制
Private Sub UserForm_Activate()
waitTime (3000) ' 3 seconds
MyDeleyedMethod
End Sub

Function waitTime(ByVal millsec As Double)
Application.Wait (Now() + millsec / 24 / 60 / 60 / 1000)
End Function

Private Sub MydelayedMethod()
MsgBox ("hello")
End Sub

实现这一结果的另一种方法是:

代码语言:javascript
复制
Private Sub UserForm_Activate()
Wait (3) ' 3 seconds
MyDeleyedMethod
End Sub

Sub Wait(seconds As Integer)
Dim now As Long
now = Timer()
Do
    DoEvents
Loop While (Timer < now + seconds)
End Sub

Private Sub MyDeleyedMethod()
MsgBox ("hello")
End Sub
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44342488

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档