乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > <em>excel</em>中用vba<em>延时</em>怎样才能,不

<em>excel</em>中用vba<em>延时</em>怎样才能,不

作者:乔山办公网日期:

返回目录:excel表格制作


你把连接数据库写成函数,主程序可以抛出异常,在异常处理那里调用你的函数

比如我写的

Private Sub UserForm_Click()
On Error GoTo ErrL
Dim s As String
s = ThisWorkbook.Sheets(1).Cells(1, 1)
MsgBox (s)
GoTo EndOk
ErrL:
MsgBox ("出错!")
EndOk:
End Sub

当点击窗体输出A1值,如果我把上面某个对象写错,那么获取不到出现异常,就会执行Errl:里的代码

格式:

On Error GoTo ErrL

可以首次调用sql函数

GoTo EndOk
ErrL:

这里调用你的sql函数

EndOk:



帮你找到的,看对你有没有用
在VB中实现延时(等待)的几种方法

在程序流程中经常要延时一段时间后再继续往下执行,在VB中常用的有以下几种方法(因为Timer控件打乱了程序的流程所以一般不用它):

1.使用Windows API函数Sleep

新建一个工程,添加一个TextBox控件和一个CommandButton控件,再将以下代码复制到代码窗口:

Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
Private Sub Command1_Click()
Text1 = "sleep begin"
Sleep 3000
Text1 = "sleep end"
End Sub

按F5执行,按下Command1按钮,程序停止执行,3秒钟内不对用户的操作做出反应,并且Text1里的内容并没有发生改变。这是怎么回事呢?原来,Sleep函数功能是将调用它的进程挂起dwMilliseconds毫秒时间,在这段时间内,此进程不对用户操作做出反应,程序中虽然将Text1的Text属性改成Sleep begin,但还没等完成对屏幕的更新进程就被挂起了,对用户来说程序象是死机一样。所以这种方法虽然简单,e68a84e799bee5baa6338但并不适用。

2.使用Timer()函数

这是用的最多的一种方法,也是在VB联机手册中所推荐的。添加一个CommandButton控件,再将以下代码添加到代码窗口中:

Private Sub Command2_Click()
Dim Savetime As Single
Text1 = "Timer begin"
Savetime = Timer '记下开始的时间
While Timer < Savetime + 5 '循环等待
DoEvents '转让控制权,以便让操作系统处理其它的事件
Wend
Text1 = "Timer ok"
End Sub

这种方法虽然也很简单,但却有有一个致命缺陷,那就是Timer函数返回的是从午夜开始到现在经过的秒数。所以Timer返回的最大值也只是60*60*24-1秒,如果从一天的23:59:58秒开始计时等待5秒,那么程序会永远地循环下去。要进行改良,就要加上判断是否又开始了新的一天,那岂不是太麻烦。下面给大家推荐另一个Windows API函数。

3.使用Windows API函数timeGetTime()

timeGetTime函数没有参数,返回值是从开机到现在所经历的毫秒数,这个毫秒数是非周期性递增的,所以不会出现Timer()函数出现的问题,而且这种方法的精确性高于上一种方法。添加一个CommandButton控件,再将以下代码添加到代码窗口中:

Private Declare Function timeGetTime Lib "winmm.dll" () As Long
Private Sub Command3_Click()
Dim Savetime As Double
Text1 = "timeGetTime begin"
Savetime = timeGetTime '记下开始时的时间
While timeGetTime < Savetime + 5000 '循环等待
DoEvents '转让控制权,以便让操作系统处理其它的事件
Wend
Text1 = "timeGetTime end"
End Sub

按F5执行程序,按这几个按钮,您可以感受一下这几种方法的优劣。
在VBA中日期的一部分加减可以使用dateadd函数。
比如dateadd("yyyy",1,now()),在今天的日期上加上一年
比如dateadd("yyyy",-1,now()),在今天的日期上减去一年。
比如dateadd("d",1,now()),在今天的日期上加上一天。
比如dateadd("d",-1,now()),在今天的日期上减去一天。
比如dateadd("m",1,now()),在今天的日期上加上一月。
比如dateadd("d",-1,now()),在今天的日期上减去一月。

加一个时间函数即可。详细加我交流。

相关阅读

  • <em>excel</em>用宏建立工作表

  • 乔山办公网excel表格制作
  • 1.首先把需要合并的excel工作薄整理到一个文件夹中,如图,用来合并到一起的工作薄的名字要注意,这里取名叫“合并工作薄”。2.打开这个excel表,直接按键ALT+F11,进入下图界面。双
关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网