VBA编程基础1:注释、变量、数据类型、赋值运算

VBA语言元素

首先是一个简单的VBA Sub过程,包含典型VBA语言元素。

Sub VBA_Demo()
'注释:这是一段VBA代码示例
  Dim Total As Long,  i As Long
  Total = 0
  For i = 1 To 100
    Total = Total + i
  Next i
  MsgBox Total
End Sub

以上过程中包含部分常见VBA语言元素:

  • 一行注释,注释行使用单引号开头
  • 一行变量声明语句,以 Dim 开头
  • 两个变量, Total 和 i
  • 两条赋值语句,Total = 0 和 Total = Total + i
  • 一个循环结构,For-Next 结构
  • 一个VBA函数,MsgBox 函数

通常每行写一条指令,但不强制遵守。在一行中可以用冒号隔开多条指令;对于稍长的代码可以使用空格和下划线组成的VBA换行连续序列。例如:

Sub OneLine()
' 使用“:”在一行中分隔多条指令
  x = 1: y = 2: z = 3: MsgBox x + y + z
End Sub
Sub LongLine()
' 使用空格加下划线可以实现代码连续换行,便于阅读
  SumValue =  _
    Worksheets("Sheet1").Range("A1").Value + _
    Worksheets("Sheet2").Range("A1").Value
End Sub

注释

VBA注释以(英文)单引号开始,“注释”是嵌入代码中的描述性文本。使用注释可以清晰描述编程思路(代码功能),便于修改和阅读代码。注释可以占用整行,也可以在代码后插入注释。为发挥注释作用,以下是一些常规提示:

  • 使用注释描述变量的目的
  • 使用注释简要描述每个过程的目的。
  • 使用注释描述对过程所做的修改。
  • 使用注释指出非标准(或常规)方式使用的函数或构件。
  • 写完代码后加注释,不如编写代码的同时写注释。
Sub CommentDemo()
'这是一个没有实际作用的过程
  x = 0  'x没有任何含义
'显示结果
  MsgBox x
End Sub

变量、数据类型和常量

“变量”是一些已命名的位于计算机内存中的存储位置,在程序执行过程中变量的值可能发生变化。“数据类型”指如何把数据存储到内存中, 如作为整数、实数或字符串等等。有时候需要引用不发生变化的值或字符串,即“常量”。

变量

尽可能用描述性的词语定义变量名称,会比较直观。此外,VBA规定了一些变量命名规则:

  • 第一个字符必须是字母,可以使用字母,数字和一些标点符号。
  • VBA变量名称不区分大小写。建议使用帕斯卡(Pascal)命名法,做法是首字母大写,如:UserName。
  • 变量名中不能包括空格和句点。有时为了可读性,可用下划线,如:User_Name。
  • 不能在变量名中嵌入特殊类型的声明字符,如#、$、%、&或!。
  • 变量名最多可以包含254个字符,但不推荐过长的变量名。

下面是一些赋值表达式,等号左侧是变量名称。每条表达把右边的值赋给左侧的变量:

x = 1
InterestRate = 0.065
DataUpdated = False
x = x + 1
'日期总是使用“月/日/年”格式定义
DateEnd = #12/31/2018#  
UserName = "哎喂可乐"

定义数据类型

VBA 内置的数据类型如下:

数据类型 所使用的字节 数值的范围
Byte 1个字节 0-255
Boolean 2个字节 True或False
Integer 2个字节 -32 768~32 767
Long 4个字节 -2 147 483 648~2 147 483 647
Single 4个字节 负值:-3.402 823E38~-1.401 298E-45
正值:1.401 298E-45~3.402 823E38
Double 8个字节 负值:-1.797 693 134 862 32E308~-4.940 656 458 412 47E-324
正值:4.940 656 458 412 47E-324~1.797 693 134 862 32E308
Currency 8个字节 -992 337 203 685 477.5808~992 337 203 685 477.5807
Decimal 12个字节 不带小数位时+/-79 228 162 514 264 337 593 543 950 335
带28个小数位时+- 7.922 816 251 426 433 759 354 395 033 5
Date 8个字节 0100年1月1日~9999年12月31日
Object 4个字节 任意对象的引用
String(变长) 10个字节+字符串的长度 0~大约20亿个字符
String(定长) 字符串的长度 1~大约65400个字符
Variant(数字) 16个字节 最大到双精度(Double)数据类型的任意数值。也可以保存诸如Empty、Error、Nothing和Null之类的特殊数值。
Variant(字符) 22个字节+字符串的长度 0~大约20亿
用户自定义 因元素类型而异 因元素类型而异

如果不为VBA中使用的某个变量声明数据类型,将默认使用Variant类型,存储为Variant类型的数据行根据处理内容不同将改变数据的类型。尽管VBA可以自动维护数据类型,但是会导致执行速度慢以及内存使用效率不高等问题。因此,最好将变量显示的声明为某种特定的数据类型,为了强制声明使用的所有变量,可在VBA模块中使用以下语句作为第一条指令:

Option Explicit

局部变量:在过程中声明的一种变量,只能作用才声明它的过程中。过程结束时,局部变量不复存在。

Sub MySub()
' 使用Dim关键字声明局部变量
  Dim TodayDate As Date
  Dim UserName As String * 50  '限定字符串最大长度为50
  Dim TextData  As String      '变长字符串

  ' 可以用一条Dim语句声明多个变量
  Dim First As Long, Last As Double 
End Sub

模块作用域下的变量:在模块的所有过程中都可以使用的变量,只要在模块的第一个过程之前(在任何过程或函数外)声明变量即可。

Dim UserName As String '模块作用域下,MySub1()和MySub2()过程中都可以使用
Sub MySub1()
  ' 第一个过程的代码
End Sub
Sub MySub2()
  ' 第二个过程的代码
End Sub

公共变量:在项目的所有VBA模块的所有过程中都可以使用的变量,需要声明在模块层次上(第一个过程之前),使用Public关键字声明而不是使用Dim声明。例如:

Public FileName as Double '公共变量

静态变量:比较特殊,这些变量在过程层次上进行变量的声明,过程结束时静态变量保持它们的值不变。如果有一条End语句终止了该过程,静态变量将丢失它们的值。注意,End语句与End Sub语句并不相同。使用Static关键字可以声明静态变量:

Sub MySub()
  Static Counter As Long '静态变量
  ' 过程的代码
End Sub

常量

使用Const关键字来声明常量。用常量代替硬编码的值或者字符串是一个非常好的习惯,可以使代码更具可读性且便于修改。比如,PI=3.1415926, 或者多次引用某个利率Rate等。

Const AppName = "哎喂可乐"
Const FirstDay As Date = #1/1/2018#
Const LunchTime = #12:00:00#
Const Rate = 0.065, Period = 12

与变量类似,常量也有作用域。可以在Sub或Function语句后声明局部常量,或使用Public关键字声明公共常量。

Public Const InterestRate As Double = 0.065

赋值语句

“赋值语句”是一条VBA指令,它进行数学(函数)计算并将结果赋给某个变量或对象。VBA使用等号(=)作为赋值运算符。以下为赋值语句示例:

x = 1
x = x+1
x = (y * 3) / (z - 4)
FileClosed = True
FileClosed = Not FileClosed 
Range("A1").Value = 2018

使用小括号()可改变运算的优先级,默认运算符的优先级如下:

运算符 运算 优先级
^ 幂运算(乘方) 1
*和/ 乘和除 2
+和- 加和减 3
& 字符串连接 4
=、<、>、<=、>=、<> 比较 5

此外,VBA提供了逻辑运算符(具体信息及实例可查看VBA帮助系统):

运算符 用途
Not 执行表达式的逻辑“非”运算
And 执行两个表达式的逻辑“与”运算
Or 执行两个表达式的逻辑“或”运算
Xor 执行两个表达式的逻辑“异或”运算
Eqv 执行两个表达式的逻辑“等价”运算
Imp 执行两个表达式的逻辑“蕴涵”运算
'Score同时满足大于等于60且小于80时,MsgBox语句将显示True
'若不满足其中一个条件或两个都不满足,则MsgBox语句将显示False
MsgBox Score >= 60 And Score <80

数组

“数组”是一组拥有相同名称的同类元素,使用数组名称和索引号可以引用数组中的某个特定元素。默认情况下,VBA数组的索引号从0开始。例如包含一周7天名称的字符串数组命名为WeekDays,那么第一个元素为WeekDays(0),第二个元素为WeekDays(1),……,第七个元素为WeekDays(6)。

声明数组:声明数组与声明普通变量类似,需在变量名后加括号。此外可以指定上界索引号,还可以指定第一个索引号、关键字To以及最后一个索引号,在括号中括起来。示例如下:

' 声明一维数组
Dim MyArray(100) As Integer        '第一个索引号默认0,上界索引号100,包含101个元素
MyArray(0) = 888 '赋值给数组中的元素
Dim YourArray(1 To 100) As Integer '第一个索引号1,上界索引号100,包含100个元素

' 声明多维数组
Dim MatrixArray(1 To 10, 1 To 10)As Integer '包含100个整数的二维数组,可认为是10*10矩阵 
MatrixArray(6, 6) = 666           '赋值给数组中的元素

'声明动态数组
Dim DynamicArray() As Integer
'动态数组使用前,必须使用ReDim语句说明包含多少个元素
'常使用一个变量(例如x)指定动态数组中元素个数,直到某个过程结束才直到个数
ReDim DynamicArray(1 To x)

对象变量

“对象变量”是代表一个完整对象的变量,如单元格区域或工作表。对象变量的作用体现在显著简化代码和提高代码执行速度两个方面。
可以像声明普通变量一样声明对象变量。例如下面代码把变量TargetAera声明为一个Range对象,并使用Set关键字把对象赋值给变量:

Dim TargetAera As Range
Set TargetAera = Range("A1:C10")

以下是没有使用对象变量的一个过程:

Sub NoObjVar()
  Worksheets("Sheet1").Range("A1:C10").Value = 666
  Worksheets("Sheet1").Range("A1:C10").Font.Bold= True
  Worksheets("Sheet1").Range("A1:C10").Font.Italic = True
  Worksheets("Sheet1").Range("A1:C10").Font.Size = 16
  Worksheets("Sheet1").Range("A1:C10").Font.Name = "微软雅黑"
End Sub

为实现与上述代码相同功能,还可以使用一个对象变量进行简化:

Sub ObjVar()
  Dim TargetAera As Range
  Set TargetAera = Worksheets("Sheet1").Range("A1:C10")
  TargetAera.Value = 666
  TargetAera.Font.Bold= True
  TargetAera.Font.Italic = True
  TargetAera.Font.Size = 16
  TargetAera.Font.Name = "微软雅黑"
End Sub

自定义数据类型

VBA允许用户创建自定义数据类型。自定义数据类型要在模块最上端与任何过程之前。例如,程序要处理一组通讯录信息,可能要创建一个名为ContactInfo的联系人信息数据类型,如下所示:

' 自定义“联系人信息”数据类型
Type ContactInfo
  Name As String
  PhoneNum As String
  Email As String
  WeChatID As String
  Birthday As Date
End Type

' 声明包含100个联系人信息元素的数组,每个元素由5部分组成
Dim MyContacts(1 To 100) as ContactInfo
MyContacts(1).Name = “哎喂可乐”
MyContacts(1).PhoneNum = "12345678"
MyContacts(1).Email ="[email protected]"
MyContacts(1).WeChatID = “***”
MyContacts(1).Birthday  = #11/11/1911#

内置函数

与大多数编程语言一样,VBA包含各种内置函数,可以简化计算和操作。

VBA语句清单和内置函数清单后续补充。

系列:
VBA编程基础1:注释、变量、数据类型、赋值运算
VBA编程基础2:处理对象和过程控制

你可能感兴趣的:(VBA编程基础1:注释、变量、数据类型、赋值运算)