ExcelVBA 快速上手之葵花宝典.doc_第1页
ExcelVBA 快速上手之葵花宝典.doc_第2页
ExcelVBA 快速上手之葵花宝典.doc_第3页
ExcelVBA 快速上手之葵花宝典.doc_第4页
ExcelVBA 快速上手之葵花宝典.doc_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

E x c e l VBA 快速上手之葵花宝典第一章 VBA语言基础 第一节 标识符 一定义 标识符是一种标识变量、常量、过程、函数、类等语言构成单位的符号,利用它可以完成对变量、常 量、过程、函数、类等的引用。 二命名规则 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) whilewend语句,只要条件为TRUE,循环就执行,这是以前 VB老语法保留下来的,如下例: while condition while I50 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 (Inte

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论