一、常量:在代码运行过程中频繁使用,但不会变化的数字或者文本.....用Const声明。
Sub 常量声明()
Const pi = 3.14159265358979
Const a = "社会平头哥,人狠话不多!"
MsgBox pi
MsgBox a
End Sub
二、变量:用来存储数据信息,且数据信息可以改变。一般用Dim声明(Private、Static、Public比较少用)。
Dim:声明模块变量,好比私家车,自己用的,不能借出。(单独模块中用,用完就电脑就从内存(数据存储在内存中)中回收了,不占茅坑)
Public:声明公共变量,好比共享单车(公交车),大家都能使用。(不同模块都可以用,用完别人用,在内存中一直占着茅坑......除非......)
.......知道Dim就可以了,其他很少用到,毕竟不是程序猿。
2.1变量命名规则:
必须使用一个字母作为第一个字符。
不能使用空格,句号(.),感叹号(!),或字符@, &, $, #在变量名称中。
名称不能超过255个字符。
不能使用Visual Basic保留关键字作为变量名。
名称最好能让人容易Get到意思,比如,声明一个关于销售额的变量,Dim SalesAmount
2.2 变量的数据类型:
【声明变量最好定义变量的数据类型,比如声明一个存储姓名的变量,应该定义为文本变量,声明一个存储日期的变量,应该定义为日期变量;但VBA可以不声明变量类型,默认为Variant类型,在代码运行的时候电脑会自行判别变量的类型,将Variant转为相应的类型,也就是交给电脑自己搞掂。好处:不用记那么多数据类型,坏处:会拉低代码效率(但一般不明显);最好还是声明类型啦!】
Sub 变量声明()
Dim sales'【默认数据类型为Variant类型】
sales = sales + 1
MsgBox sales
End Sub
***********【运行代码后,转为Integer整型】
------------------------------------------【容易误解的变量声明】-----------------------------------------------
Sub 声明变量1()
Dim sales As Double'单个变量声明书写
Dim salesdata As Double, index As Integer, startdate As Date'连续的变量声明书写,逗号隔开
Dim x, y, z As Integer'上面的变量类型都有明确的定义,这里x,y是Variant类型,而不是Integer类型。很容易就将x, y误解为Integer类型。【可以透过本地窗口看到每个变量的数据类型】
End Sub
【VBA还可以不声明变量,但觉得这样真的不好】
三、给变量赋值:给变量赋值直接用“=”号,如下面的变量x经过多次运算从0变化为3。
Sub 给变量赋值()
Dim x As Integer
Dim y As Integer
x = 0 '初始值为0
y = 0 '初始值为0
x = x + 1 'x=0+1-->x=1,开始x=0,0+1=1,然后将1再返回给变量x,x从0变为1.
'x = x + 1等号左边的x为变量,等号右边的x是数值0
x = x + 1 'x=1+1-->x=2
x = x + 1 'x=2+1-->x=3
y = x + y 'y=3+0-->y=3
y = x + y 'y=3+3-->y=6
y = x + y 'y=3+6-->y=9
Debug.Print x, y'立即窗口看x,y最后等于神马
End Sub
四、Variant类型和“+”,“&”符合
Variant被称为变体,意思是数据类型是未确定的,看实际的数据类型由电脑智能判断。
Sub 变体变变变()
Dim x As Variant
Dim y As Variant
Dim z As Variant
x = 1
y = "吃包辣条压压惊"
z = #5/20/2017#
End Sub
【数据类型电脑给自动转换了】
-----------------------------------------------------------------------------------------------------------------------------
【一旦定义了变量的数据类型,那么给变量赋值的时候,数据类型必须是匹配的】
如x为整型,则必须是整数,y是字符串(文本),则不能是日期(当然可以将日期转为文本来匹配数据类型)..........
【当数据都是文本时,+和&都是起到连接作用】
【当数据都是数值时,+表示相加,&起链接作用】
【数值 & 文本】
【数值+文本】会错误