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

相关文章

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异