赞
踩
当你大VBA程序得越来越大,要很好地维护这么多的代码行是很困难的。要让你的程序容易编写、理解和改变,你就应该使用井井有条的结构化程序。你只要简单地将大问题分成一些可以同时执行的小问题就行。在VBA中,你可以通过创建一个主过程和一个或多个子过程来实现它。因为主过程和子过程都是子程序下面的例子显示过程AboutUser。该过程要求用户姓和名,并且将姓和名从全名中分离出来。最后的语句显示用户的姓,随后是逗号和名。你再读下去,该过程将被分割成几个任务,以示范使用主过程,子过程和函数的概念。
- Sub AboutUser()
- Dim fullName As String
- Dim firstName As String
- Dim lastName As String
- Dim space As Integer
- 'get input from user 从用户获取信息
- fullName = InputBox("Enter first and last name:")
- 'get first and last name strings 获得姓和名字符串
- space = InStr(fullName, " ")
- firstName = Left(fullName, space - 1)
- lastName = Right(fullName, Len(fullName) - space)
- 'display last name, first name 显示姓和名
- MsgBox lastName & ", " & firstName
- End Sub
主过程:
- Sub AboutUserMaster()
- Dim first As String, last As String, full As String
- Call GetUserName(full)
- first = GetFirst(full)
- last = GetLast(full)
- Call DisplayLastFirst(first, last)
- End Sub
上面显示的主过程通过调用适当的子程序和函数来控制程序的主流程。该主过程以变量生命开始,第一条语句Call GetUserName (full)调用子过程GetUserName并且传递给一参数——变量full的内容。
因为变量在执行调用语句之前没有赋与任何值,所以它的值是一个空字符串(“ ”)。注意,子过程的名称在Call之后。尽管你在调用过程时并没有要求使用关键字Call,但是,你在调用一个需要参数的过程时就必须使用它。参数列表必须包括在括号里面。
子过程:
- Sub GetUserName(fullName As String)
- fullName = InputBox("Enter first and last name:")
- End Sub
过程GetUserName示范了两个非常重要的VB编程概念:如何传递参数给一子程序以及如何将值从子程序传递回给主调过程。
在主过程(见第二步)中,你调用了过程GetUserName,并且将其作为一参数传递:变量full。该变量被参数fullName接收,该参数子过程GetUserName的Sub语句里声明了。因为在VB调用子过程GetUserName的时候,变量full包含一空字符串,参数fullName同样也接收了这个空字符串。当VB显示对话框并且获得用户的姓名时,这个姓名将赋给参数fullName。赋给参数的值被传递回给子过程执行后的匹配参数。因此,当VB返回主过程时,变量full就回包含用户的姓名。
传递给子过程的自变量将被其参数接收。注意,参数名称(fullName)后面紧跟着数据类型的声明(AsString)。虽然,参数的数据类型必须和相匹配的自变量的数据类型一致,但是,不同的名称还是可以使用给一个自变量和它相应的参数。
技巧:自变量(Arguments)和参数(Parameters)
①自变量是传递给一个子过程的变量,常量或表达式
②参数则只是接收值并传递给子过程的变量
- Sub AboutUserMaster()
- Dim first As String, last As String, full As String
- Call GetUserName(full)
- first = GetFirst(full)
- last = GetLast(full)
- Call DisplayLastFirst(first, last)
- End Sub
- Sub GetUserName(fullName As String)
- fullName = InputBox("Enter first and last name:")
- End Sub
- Function GetFirst(fullName As String)
- Dim space As Integer
- space = InStr(fullName, " ")
- GetFirst = Left(fullName, space - 1)
- End Function
- Function GetLast(fullName As String)
- Dim space As Integer
- space = InStr(fullName, " ")
- GetLast = Right(fullName, Len(fullName) - space)
- End Function
- Sub DisplayLastFirst(firstName As String, lastName As String)
- MsgBox lastName & ", " & firstName
- End Sub
技巧:使用子过程的好处
①维护多个子过程要比维护一个大过程要容易得多
②由一个子过程执行的任务可以给好几个过程使用
③每个子过程再放入主过程里之前就被单独测试
④多个程序员可以负责各自的子过程,这些子过程再构建一个大的程序
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。