分享

Excel VBA(宏)精简(一)

 昵称5012511 2010-12-10

标识符:
.定义
标识符是一种标识变量,常量,过程,函数,类等语言构成单位的符号,利用它可以完成对变量,常量,过程,函数,类等的引用.
.命名规则
1)
字母打头,由字母,数字和下划线组成, A987b_23Abc
2)
字符长度小于 40,(Excel2002以上中文版等,可以用汉字且长度可达 254个字符)
3)
不能与 VB保留关键字重名, public, private, dim, goto, next, with, integer, single

运算符:
定义:运算符是代表 VB某种运算功能的符号. 1)赋值运算符 =
2)
数学运算符 &, + (字符连接符 ), +(),-(), Mod(取余), (整除),*(),/(),-(负号),^(指数)
3)
逻辑运算符 Not(), And(), Or(), Xor(异或), Eqv(相等), Imp(隐含)
4)
关系运算符 = (相同), <>(不等),>(大于),>=(不小于), B And C250 Then x=x-100 或者,可以使用块形式的语法: If condition Then [statements] [ElseIf condition-n Then [elseifstatements] ... [Else [elsestatements]] End If
1:
If Number < 10 Then Digits = 1 ElseIf Number 0 then Gosub Routine1 :Debug.print num:Exit sub
Routine1:
Num=num/5
Return
End sub 4) while…wend
语句,只要条件为TRUE,循环就执行,这是以前 VB老语法保留下来的,如下例: while condition 'while I<50 [statements] 'I=I+1 wend 'Wend
.错误语句处理
执行阶段有时会有错误的情况发生,利用On Error语句来处理错误,启动一个错误的处理程序.语法如下: On Error Goto Line '当错误发生时,会立刻转移到line行去
On Error Resume Next '
当错误发生时,会立刻转移到发生错误的下一行去
On Erro Goto 0 '
当错误发生时,会立刻停止过程中任何错误处理过程

过程和函数:
过程是构成程序的一个模块,往往用来完成一个相对独立的功能.过程可以使程序更清晰,更具结构性.VBA具有四种过程:Sub 过程, Function函数, Property属性过程和 Event事件过程.
.Sub过程
Sub
过程的参数有两种传递方式:按值传递(ByVal)和按地址传递 (ByRef).如下例:
Sub password (ByVal x as integer, ByRef y as integer)
If y=100 then y=x+y else y=x-y x=x+100
End sub
Sub call_password ()
Dim x1 as integer
Dim y1 as integer x1=12 y1=100 Call password (x1,y1) '
调用过程方式:1. Call 过程名 (参数 1, 参数 2…) ; 2. 过程名 参数 1, 参数 2… debug.print x1,y1 '结果是12, 112, y1按地址传递改变了值, x1按值传递,未改变原值
End sub
. Function函数
函数实际是实现一种映射,它通过一定的映射规则,完成运算并返回结果.参数传递也两种:按值传递(ByVal)和按地址传递 (ByRef).如下例:
Function password(ByVal x as integer, byref y as integer) as boolean
If y=100 then y=x+y else y=x-y x=x+100 if y=150 then password=true else password=false
End Function
Sub call_password ()
Dim x1 as integer
Dim y1 as integer x1=12 y1=100 if password then '
调用函数: 1. 作为一个表达式放在=右端 ; 2. 作为参数使用 debug.print x1
end if End sub
. Property属性过程和 Event事件过程
这是 VB在对象功能上添加的两个过程,与对象特征密切相关,也是 VBA比较重要组成,技术比较复杂,可以参考相关书籍.

内部函数:
VBA程序语言中有许多内置函数,可以帮助程序代码设计和减少代码的编写工作.
.测试函数
IsNumeric(x) '
是否为数字 , 返回 Boolean结果,True or False
IsDate(x) '
是否是日期 , 返回 Boolean结果,True or False
IsEmpty(x) '
是否为 Empty, 返回 Boolean结果,True or False
IsArray(x) '
指出变量是否为一个数组.
IsError(expression) '
指出表达式是否为一个错误值 IsNu ll(expression) '指出表达式是否不包含任何有效数据 (Null).
IsObject(identifier) '
指出标识符是否表示对象变量
.数学函数
Sin(X), Cos(X), Tan(X), Atan(x)
三角函数,单位为弧度
Log(x)
返回x的自然对数
Exp(x)
返回 ex
Abs(x)
返回绝对值
Int(number),Fix(number)
都返回参数的整数部分,区别: Int -8.4 转换成 -9, Fix -8.4 转换成 -8
Sgn(number)
返回一个 Variant (Integer),指出参数的正负号
Sqr(number)
返回一个 Double,指定参数的平方根
VarType(varname)
返回一个 Integer,指出变量的子类型
Rnd(x)
返回 0-1之间的单精度数据,x为随机种子
.字符串函数
Trim (string)
去掉 string左右两端空白
Ltrim( string)
去掉 string左端空白
Rtrim( string)
去掉 string右端空白
Len(string)
计算 string长度 Left(string, x) string左段x个字符组成的字符串
Right(string, x)
string右段x个字符组成的字符串
Mid(string, start,x)
string start位开始的x个字符组成的字符串
Ucase(string)
转换为大写
Lcase(string)
转换为小写
Space(x)
返回x个空白的字符串 As c(string) 返回一个 integer,代表字符串中首字母的字符代码
Chr(charcode)
返回 string,其中包含有与指定的字符代码相关的字符
.转换函数
CBool(expression)
转换为 Boolean CByte(expression) 转换为 Byte CCur(expression) 转换为 Currency CDate(expression) 转换为 Date CDbl(expression) 转换为Double CDec(expression) 转换为 Decemal CInt(expression) 转换为 Integer CLng(expression) 转换为 Long CSng(expression) 转换为 Single CStr(expression) 转换为 String CVar(expression) 转换为 Variant
Va l(string)
转换为数据型
Str(num ber)
转换为String
.时间函数
Now
返回一个 Variant (Date),根据计算机系统设置的日期和时间来指定日期和时间.
Date
返回包含系统日期的 Variant (Date).
Time
返回一个指明当前系统时间的 Variant (Date).
Timer
返回一个Single, 代表从午夜开始到现在经过的秒数.
TimeSerial(hour, minute, second)
返回一个 Variant (Date),包含具有具体时,,秒的时间.
DateDiff(interval, date1, date2[, firstdayofweek[, firstweekofyear]])
返回 Variant (Long) 的值,表示两个指定 日期间的时间间隔数目 Second(time) 返回一个 Variant (Integer),其值为 0 59 之间的整数,表示一分钟之中的某个秒
Minute(time)
返回一个 Variant (Integer),其值为 0 59 之间的整数,表示一小时中的某分钟
Hour(time)
返回一个 Variant (Integer),其值为 0 23 之间的整数,表示一天之中的某一钟点
Day(date)
返回一个 Variant (Integer),其值为 1 31 之间的整数,表示一个月中的某一日
Month(date)
返回一个 Variant (Integer),其值为 1 12 之间的整数,表示一年中的某月
Year(date)
返回 Variant (Integer),包含表示年份的整数.
Weekday(date, [firstdayofweek])
返回一个 Variant (Integer),包含一个整数,代表某个日期是星期几.

 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多