概要

对于一般的 VBA 程序来说, 可能一个或几个函数就行了. 毕竟, VBA 只是作为 excel 的辅助工具来用的.

但是, 随着 VBA 写的越来越多, 用个工程来管理就有必要了, 而一个代码工程的基础, 就是 函数模块.

函数

VBA 的中的函数有 2 种, 一种是 Sub, 一种是 Function 在 VBA 中, 其实 Sub 叫过程, 不叫函数, 它们的区别有 2 个:

  1. Function 有返回值, Sub 没有
  2. Sub 可以直接执行, Function 必须被调用才能执行

Sub 和 Function 的示例如下:

  1. 1 Option Explicit
  2. 2
  3. 3 Sub CallAnotherMod()
  4. 4 Dim sum As Integer
  5. 5 sum = Add(2, 3)
  6. 6 Debug.Print sum
  7. 7 End Sub
  8. 8
  9. 9 Function Add(a As Integer, b As Integer) As Integer
  10. 10 Debug.Print a
  11. 11 Debug.Print b
  12. 12 Add = a + b
  13. 13 End Function

注意, 函数的返回值, 是将结果赋值给函数名本身 Add = a + b , 否则返回值一直是 0

模块

模块化的目的是复用, 对于一些通用的功能, 我们可以封装成模块并导出. 这样, 在不同的 VBA 工程中导入已有的模块, 就不用重复的造轮子.

模块的导出很方便, 只要在对应的模块上点击右键, 导出即可, 导出后是一个 *.bas 的文件.

一般模块

一般模块简单明了, 我们之前写的 Sub 或者 Function 其实都在一个默认的一般模块中. 下面的示例工程, 我创建 2 个模块, 分别是 Main 和 MyMath, Main 用来测试, MyMath 中是为了以后复用的函数.

  • Main 模块:

    1. 1 Option Explicit
    2. 2
    3. 3 Sub CallAnotherMod()
    4. 4 Debug.Print "2 + 3 = " & (Add(2, 3))
    5. 5 Debug.Print "2 * 3 = " & (Multiply(2, 3))
    6. 6
    7. 7 End Sub
  • MyMath 模块:

    1. 1 Option Explicit
    2. 2
    3. 3 Function Add(A As Integer, B As Integer) As Integer
    4. 4 Add = A + B
    5. 5 End Function
    6. 6
    7. 7 Function Multiply(A As Integer, B As Integer) As Integer
    8. 8 Multiply = A * B
    9. 9 End Function
  • 运行 Main 模块, 结果如下:

    1. 2 + 3 = 5
    2. 2 * 3 = 6

类模块

除了像上面那样通过函数来封装一些功能, VBA 也可以按照类的方式来组织, 熟悉面向对象设计的开发人员可能更喜欢这种方式.

  • 新建一个类模块, 和新建普通模块的步骤一样, 只是新建之前选择的类型是 类模块

  • 比如我们新建一个 MathCls 的类模块:

    1. 1 Option Explicit
    2. 2
    3. 3 ' 常量, class说明
    4. 4 Const MathClsName = "math class"
    5. 5
    6. 6 Dim MathA As Integer
    7. 7 Dim MathB As Integer
    8. 8
    9. 9 ' 相当于其他面向对象语言中的 set 方法
    10. 10 Public Property Let A(numA As Integer)
    11. 11 MathA = numA
    12. 12 End Property
    13. 13
    14. 14 ' 相当于其他面向对象语言中的 get 方法
    15. 15 Public Property Get A() As Integer
    16. 16 A = MathA
    17. 17 End Property
    18. 18
    19. 19 ' 相当于其他面向对象语言中的 set 方法
    20. 20 Public Property Let B(numB As Integer)
    21. 21 MathB = numB
    22. 22 End Property
    23. 23
    24. 24 ' 相当于其他面向对象语言中的 get 方法
    25. 25 Public Property Get B() As Integer
    26. 26 B = MathB
    27. 27 End Property
    28. 28
    29. 29 Function Add() As Integer
    30. 30 Add = MathA + MathB
    31. 31 End Function
  • 用来测试的 Main 模块, 这是个普通模块

    1. 1 Option Explicit
    2. 2
    3. 3 Sub CallAnotherMod()
    4. 4
    5. 5 Dim mc As New MathCls
    6. 6 mc.A = 2
    7. 7 mc.B = 3
    8. 8
    9. 9 Debug.Print (mc.Add())
    10. 10
    11. 11 End Sub

总结

无论采用那种方式来封装, 要看需要封装的功能适合那种方式. 这 2 种方式就像函数式和面向对象编程一样, 没有谁高谁低, 各自有适合的场景.

VBA基础 - 函数和模块的更多相关文章

  1. python基础,函数,面向对象,模块练习

    ---恢复内容开始--- python基础,函数,面向对象,模块练习 1,简述python中基本数据类型中表示False的数据有哪些? #  [] {} () None 0 2,位和字节的关系? # ...

  2. Python基础之函数和模块

    函数的基本使用 函数的定义:把具有独立功能的代码块组织成一个小模块,在需要的时候调用.或者说,函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数的使用:1.定义函数:2.调用函数 ...

  3. 零基础学python之函数与模块(附详细的代码和安装发布文件过程)

    代码重用——函数与模块 摘要:构建函数,创建模块,安装发布文件,安装pytest和PEP 8插件,确认PEP8兼容性以及纠错 重用代码是构建一个可维护系统的关键. 代码组是Python中对块的叫法. ...

  4. python基础-----函数/装饰器

    函数 在Python中,定义一个函数要使用def语句,依次写出函数名.括号.括号中的参数和冒号:,然后,在缩进块中编写函数体,函数的返回值用return语句返回. 函数的优点之一是,可以将代码块与主程 ...

  5. 十八. Python基础(18)常用模块

    十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...

  6. VBA基础之Excel 工作薄(Book)的操作(三)

    三. Excel 工作薄(Book)的操作1. Excel 创建工作薄(Book) Sub addWorkbook() Workbooks.Add End Sub 2. Excel 打开工作薄(Boo ...

  7. Python基础-包与模块

    Python基础-包与模块 写在前面 如非特别说明,下文均基于Python3 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含 ...

  8. Excel VBA基础教程

    https://www.w3cschool.cn/excelvba/excelvba-basics.html Excel VBA语言基础 VBA语言的基础认识 详解VBA编程是什么 excel处理录制 ...

  9. Python学习教程(Python学习视频_Python学些路线):Day06 函数和模块的使用

    Python学习教程(Python学习视频_Python学些路线):函数和模块的使用 在讲解本章节的内容之前,我们先来研究一道数学题,请说出下面的方程有多少组正整数解. $$x_1 + x_2 + x ...

随机推荐

  1. golang:exported function Script should have comment or be unexported

    当自己定义的包被外部使用时,如果不遵循一定的规范,那么会出现讨厌的绿色纹条,还会警告: 虽然不会影响运行,但是也令人讨厌,那么如何解决这个问题呢? 为结构体或者变量或者方法添加注释,并且开头必须是结构 ...

  2. css top,right,bottom,left设置为0有什么用?它和width:100%和height:100%有什么区别?

     壹 ❀ 引 当我们使用position属性时,总免不了与top,left,right,bottom四个属性打交道,那么这四个属性都设置为0时有什么用,与宽高设置100%又有什么区别?本文对此展开讨论 ...

  3. 要想精通Mybatis?从手写Mybatis框架开始吧!

    1.Mybatis组成 动态SQL Config配置 Mapper配置 2.核心源码分析 Configuration源码解析 SqlSessionFactory源码解析 SqlSession源码解析 ...

  4. apt-get failed:The following signatures were invalid: BADSIG

    参考如下链接: https://askubuntu.com/questions/131601/gpg-error-release-the-following-signatures-were-inval ...

  5. ubuntu 16.04无法连接网络;双系统无法上网;连接已断开,你现在处于断开状态

    先描述一一下我的问题,若和你的一样,请继续往下看. 我是在原有Windows7系统的台式计算机中安装了ubuntu 16.04,所以目前这台计算机是双系统.打开Windows系统时有线网络正常链接.但 ...

  6. 关于excel中的vlookup就是查找当前列对应的下一列的值的使用

    关于excel中的vlookup就是查找当前列对应的下一列的值的使用 vlookup的使用一些说明 vlookup函数一个4个参数解释下 vlookup(查找的值,表格范围,表格范围中第几列的值,0是 ...

  7. oracle学习笔记(十七) PL/SQL高级应用

    PL/SQL高级应用 动态SQL 在PL/SQL中,不能直接执行DDL(create,alter,drop),得使用动态SQL,当然,除了DDL,动态SQL也可以执行DML(select,insert ...

  8. C# 简单的进程间通信方式

    只想实现一个简单的进程建通信,有什么快速实现方式? 1 进程单例需求 / Windows 消息与 IMessageFilter 如果需求是实现一个进程单例,在启动第二个进程时,期望能自动唤起第一个进程 ...

  9. Java技巧——比较两个日期相差的天数

    Java技巧——比较两个日期相差的天数 摘要:本文主要记录了在Java里面如何判断两个日期相差的天数. 判断两个Date类型的日期之间的天数 通过计算毫秒数判断: public static void ...

  10. 1.java容器基本内容

    目录 java容器概述 1.collection接口 (1)collection接口方法 (2)set接口实现类 (3)list接口实现类 (4)queue接口实现类 2.map接口 java容器概述 ...