过程和函数
时 间:2019-08-23 21:26:31
作 者:杨雪 ID:42182 城市:南京
摘 要:VBA代码有两种组织形式,一种是过程,另一种就是函数。其实过程和函数有很多相同之处,除了使用的关键字不同之外,还有不同的是:
正 文:
VBA代码有两种组织形式,一种是过程,另一种就是函数。其实过程和函数有很多相同之处,除了使用的关键字不同之外,还有不同的是:
- 函数有返回值,过程没有
- 函数可以在Access窗体,查询中像一般的Access函数那样使用,但过程不可以
- 过程可以指定给Access窗体中的按钮或者图片等对象,但是函数不可以
- 函数只能在被调用时执行,比如在过程中调用,或者在另一个函数中调用,或者在Access窗体中调用。但不能直接执行,而过程是可以的
1. 过程 Sub
过程以Sub开头,End Sub结束,过程中需要执行的代码放在中间。格式如下:
Sub 过程名()
' 需要在过程中执行的代码
End Sub
过程名后面的括号是必须的,过程可以带参数,就放置在括号里面,稍后会有说明。
过程示例:
Sub test() Debug.Print "Hello" End Sub
2. 函数 Function
与过程类似,函数的格式如下:
Function 函数名(参数1, 参数2, ...) As 数据类型 ' 需要在函数中执行的代码 函数名 = 函数执行后的结果 End Function
函数名后面的括号是必须的,函数通常都带有参数,放置在括号里面。函数也可以不带参数,但这种情况下的函数通常没什么意义。
括号后面的 As 数据类型 虽然并不是必须的,但是我强烈建议加上。因为函数通常都需要有返回值,这个数据类型就表示着返回值的数据类型。
函数体最后通常都带有一条返回值语句,把函数执行的结果赋值给函数名,就可以在调用这个函数的地方得到这个函数的执行结果。这个返回结果的数据类型应该与函数名后面As的数据类型一致,否则可能会出错。
函数示例:
Function my_sum(n1 as Integer, n2 as Integer) As Integer Dim s As Integer s = n1 + n2 my_sum = s End Function
上例中定义了一个名为my_sum的函数,它接受两个类型为Integer的参数,并且返回值是Integer类型。在函数内部计算了这两个参数相加的和,并把这个和作为返回值赋给my_sum。可以通过调用这个函数,并传递相应的参数,获得它的返回值。
定义函数后,就可以在VBA中的过程,或者其它函数中使用这个函数了。
3. 过程和函数的调用
前面说过,过程和函数,都可以是被相互调用的。
3.1 过程的调用
格式1:
Call 过程名
格式2:
Call 过程名(参数1, 参数2, ...)
如果过程不带参数,那么可以使用第1种格式,过程名后面不需要括号
如果过程带有参数,则要按照参数的顺序依次把参数写到过程名后面的括号中。即使用第2种格式。
3.2 函数的调用
函数的调用通常会在调用时把其赋值给一个变量,以获取函数返回值。
Sub test() Dim s As Integer s = my_sum(5, 5) Debug.Print s End SubFunction my_sum(n1 As Integer, n2 As Integer) As Integer Dim s As Integer s = n1 + n2 my_sum = s End Function
这里应该提出的是,函数应当要有返回值的,因为如果不需要返回值,那就应该直接使用过程而不是函数了。
4. 参数的使用
参数和使用对于过程和函数都是一样的。所以本节的内容对过程和函数都适用。
参数可分为可选参数和必选参数两种。必选参数在调用(过程或函数时)必须加上,否则会报错。可选参数则可写可不写。默认是必选参数,可选参数在定义时用Optional关键字声明,并且可选参数必须放在参数列表的最后面。
4.1 必选参数
必选参数在定义时放置在过程或函数名后面的括号中,格式为:
参数名 As 参数类型
如:
Sub sub_test(s As String) Debug.Print s End Sub
在调用时,必须传入参数:
Sub test() Call sub_test("hello") End Sub
4.2 可选参数
格式与必选参数类似,只是在参数名前面用Optional声明参数是可选的。
Optional 参数名 As 参数类型
如:
Sub sub_test(Optional s As String) Debug.Print s End Sub
在调用上述过程时,可以不传入参数,此时则不会输出任何东西,也不会报错,因为参数是可选的。如果传入了参数,则会输出这个参数。
可选参数还可以设置默认值,即如果在调用时不显式传入这个参数的话,那么就使用定义时所使用的值。如下过程:
Sub sub_test(Optional s As String = "Hello, World")
Debug.Print s
End Sub
带参数调用:
Sub test()
Call sub_test("I am a boy")
End Sub
输出:I am a boy
不带参数调用:
Sub test()
Call sub_test
End Sub
输出:Hello, World
4.3 同时使用可选参数与必选参数
此时可选参数必须放在最后
Sub sub_test(var As Integer, Optional s As String = "Hello, World")
Debug.Print var
Debug.Print s
End Sub
只传入必选参数:
Sub test()
Call sub_test(50)
End Sub
输出:
50
Hello, World
同时传入可选参数与必选参数:
Sub test()
Call sub_test(50, "Hi, Meinv")
End Sub
输出:
50
Hi, Meinv
Access软件网官方交流QQ群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台--对上传...(11.22)
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)
- Access系统自带的日期选择器不...(11.08)