ExcelVBA之传递参数给一子程序以及如何将值从子程序传递回给主调过程

2024-01-18 22:08

本文主要是介绍ExcelVBA之传递参数给一子程序以及如何将值从子程序传递回给主调过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当你大VBA程序得越来越大,要很好地维护这么多的代码行是很困难的。要让你的程序容易编写、理解和改变,你就应该使用井井有条的结构化程序。你只要简单地将大问题分成一些可以同时执行的小问题就行。在VBA中,你可以通过创建一个主过程和一个或多个子过程来实现它。因为主过程和子过程都是子程序下面的例子显示过程AboutUser。该过程要求用户姓和名,并且将姓和名从全名中分离出来。最后的语句显示用户的姓,随后是逗号和名。你再读下去,该过程将被分割成几个任务,以示范使用主过程,子过程和函数的概念。

Sub AboutUser()Dim fullName As StringDim firstName As StringDim lastName As StringDim 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 StringCall 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 StringCall 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 Integerspace = InStr(fullName, " ")GetFirst = Left(fullName, space - 1)
End Function
Function GetLast(fullName As String)Dim space As Integerspace = InStr(fullName, " ")GetLast = Right(fullName, Len(fullName) - space)
End Function
Sub DisplayLastFirst(firstName As String, lastName As String)MsgBox lastName & ", " & firstName
End Sub

技巧:使用子过程的好处
①维护多个子过程要比维护一个大过程要容易得多
②由一个子过程执行的任务可以给好几个过程使用
③每个子过程再放入主过程里之前就被单独测试
④多个程序员可以负责各自的子过程,这些子过程再构建一个大的程序

这篇关于ExcelVBA之传递参数给一子程序以及如何将值从子程序传递回给主调过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/620405

相关文章

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

Redis指南及6.2.x版本安装过程

《Redis指南及6.2.x版本安装过程》Redis是完全开源免费的,遵守BSD协议,是一个高性能(NOSQL)的key-value数据库,Redis是一个开源的使用ANSIC语言编写、支持网络、... 目录概述Redis特点Redis应用场景缓存缓存分布式会话分布式锁社交网络最新列表Redis各版本介绍旧

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

Jvm sandbox mock机制的实践过程

《Jvmsandboxmock机制的实践过程》:本文主要介绍Jvmsandboxmock机制的实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景二、定义一个损坏的钟1、 Springboot工程中创建一个Clock类2、 添加一个Controller

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、