1、Excel_VBA_编程教程(2010 新春版)http:/2010 新春版2010.2.18Excel_VBA_编程教程(2010 新春版)http:/目录一、VBA 语言基础.1第一节标识符1第二节运算符1第三节数据类型1第四节变量与常量1第五节数组2第六节注释和赋值语句2第七节书写规范2第八节判断语句2第九节循环语句3第十节其他类语句和错误语句处理4第十一节过程和函数4一Sub 过程.4二Function 函数 5三Property 属性过程和 Event 事件过程.5第十二节内部函数.5一测试函数5二数学函数5三字符串函数5四转换函数6五时间函数6第十三节文件操作6文件6删除6打开6读
2、入7写入7关闭7其他文件函数7二、VISUALBASIC 程序设计网络教学.1第一课 VBA 是什么.11.1VBA 是什么11.2EXCEL 环境中基于应用程序自动化的优点1Excel_VBA_编程教程(2010 新春版)http:/1.3 录制简单的宏11.4 执行宏 21.5 查看录制的代码21.6 编辑录制的代码31.7 录制宏的局限性31.8 小结3第二课处理录制的宏32.1 为宏指定快捷键32.2 决定宏保存的位置42.3 个人宏工作簿42.3.1 保存宏到个人宏工作簿42.3.2 使用并编辑个人宏工作簿中的宏42.4 将宏指定给按钮42.5 将宏指定给图片或其他对象52.6 小结
3、 5第三课学习控件.5-页面 2-3.1EXCEL 开发过程简介53.2 认识不同的控件53.3 向工作表添加控件63.4 设置控件的特性63.5 给控件命名63.6 使用用户窗体63.7 疑难解答 7第四课理解变量和变量的作用74.1 代码存在的位置:模块74.2 对模块的概览74.2.1 创建过程84.2.2 运行宏 9Excel_VBA_编程教程(2010 新春版)http:/4.3 保存对模块所做的改变94.4 变量 94.4.1 变量的数据类型94.4.2 用 Dim 语句创建变量(声明变量)104.4.3 变量命名的惯例.104.4.4 使用数组.104.4.5 变量赋值.11第五
4、课利用 VBA 设置工作表使用权限.111使用 WITH 语句。2使用对象变量。.方法 3:减少对象的激活和选择方法 4:关闭屏幕更新第六课提高 EXCEL 中 VBA 的效率12方法 1:尽量使用 VBA 原有的属性、方法和 WORKSHEET 函数12方法 2:尽量减少使用对象引用,尤其在循环中.121使用 With 语句。122使用对象变量。123在循环中要尽量减少对象的访问。13方法 3:减少对象的激活和选择13方法 4:关闭屏幕更新13第七课如何在 EXCEL 里使用定时器.13三、学习微软 EXCEL2002VBA 编程和 XML,ASP 技术.15第一章电子表格自动化简介和了解宏
5、命令.151 了解宏152 宏命令的普通应用153 写宏之前的计划164 录制宏175 运行宏186 修改宏代码197 添加注释218 分析宏代码229 清除宏代码2310 测试修改好的宏2411 两个层面运行宏的方法2412 完善你的宏代码2513 重新命名宏27Excel_VBA_编程教程(2010 新春版)http:/14 运行宏的其它方法27-页面 3-15 使用键盘快捷键运行宏2716 通过菜单运行宏2817 通过工具栏按钮运行宏3018 通过工作表里面的按钮运行宏3119 保存宏3220 打印宏3221 保存宏在个人宏工作簿3222 打开含有宏的工作簿3423VB 编辑窗口.352
6、4 了解工程浏览窗口3525 了解属性窗口3626 了解代码窗口3627VB 编辑器里的其它窗口3828 接下来39第二章 VBA 第一步391 了解指令,模块和过程392VBA 工程命名393 模块重命名404 从其它工程调用过程415 了解对象,属性和方法426 学习对象,属性和方法437 句法和文法458 打断很长的 VBA 语句479 了解 VBA 错误4710 查找帮助4911 语法和编程快捷助手5012 属性/ 方法列表5113 常数列表5114 参数信息5215 快速信息5216 自动完成关键字5217 缩进/ 凸出5318 设置注释块/解除注释块5319 使用对象浏览器5320
7、 使用 VBA 对象库5821 用对象浏览器来定位过程5922 使用立即窗口5923 获取立即窗口里的信息61Excel_VBA_编程教程(2010 新春版)http:/24 学习对象6225 电子表格单元格操作6226 使用 RANGE 属性6227 使用 CELLS 属性6228 使用 OFFSET 属性6329 选择单元格的其它方法6430 选择行和列6431 获取工作表信息6532 往工作表输入数据6533 返回工作表中的信息6534 单元格格式6635 移动,复制和删除单元格6636 操作工作簿和工作表6737 操作窗口(WINDOWS).6738 管理 EXCEL 应用程序68-页
8、面 4-39 接下来68第三章了解变量,数据类型和常量.691 保存 VBA 语句的结果692 变量是什么693 数据类型694 如何产生变量705 如何声明变量716 明确变量的数据类型727 变量赋值738 强制声明变量759 了解变量范围7610 过程级别(当地)变量7611 模块级别变量7712 工程级别变量7713 变量的存活期7814 了解和使用静态变量7815 声明和使用对象变量7916 使用明确的对象变量8017 查找变量定义8018 在 VB 过程里面使用常量8019 内置常量8120 接下来82第四章 VBA 过程:子程序和函数82Excel_VBA_编程教程(2010 新
9、春版)http:/1.关于函数过程.822.创建函数过程.823.执行函数过程.844.从工作表里运行函数过程.845.从另外一个 VBA 过程里运行函数过程 .856.传递参数.867.明确参数类型.878.按地址和按值传递参数.889.使用可选的参数.8810.定位内置函数.8911.使用 MSGBOX 函数.9012.MSGBOX 函数的运行值 .9413.使用 INPUTBOX 函数9514.数据类型转变.9615.使用 INPUTBOX 方法9716.使用主过程和子过程.10017.接下来 .102第五章基于 VBA 做决定1021.关系和逻辑运算符.1022.IFTHEN 语句.1
10、033.基于多于一个条件的决定.1054.THEIFTHENELSE 语句.1065.IFTHENELSEIF 语句1086.嵌套的 IFTHEN 语句.1107.SELECTCASE 语句.1108.和 CASE 子句一起使用 IS.1129.确定 CASE 子句里数值的范围11310.在 CASE 子句里确定多个表达式.114-页面 5-11.接下来 .114第六章在 VBA 中重复操作.1141.DOLOOPS:DOWHILE 和 DOUNTIL1142.观察过程执行.1173.WHILEWEND 循环1184.FORNEXT 循环.1195.FOREACHNEXT 循环.1207.提前
11、跳出循环.121Excel_VBA_编程教程(2010 新春版)http:/8.循环嵌套.1229.接下来.122第七章利用 VBA 数组管理数据清单和表格1221.了解数组.1232.声明数组.1243.数组的上界和下界.1244.在 VBA 过程里使用数组.1245.数组和循环语句.1256.使用二维数组.1277.静态和动态数组.1288.数组函数.1299.ARRAY 函数.13010.ISARRAY 函数.13011.ERASE 函数.13112.LBOUND 函数和 UBOUND 函数13113.数组中的错误.13214.数组作为参数.13415.接下来 .134第八章利用 VBA
12、 操纵文件和文件夹.1341.获取当前文件夹的名称(CURDIR 函数).1352.更改文件或文件夹名称(NAME 函数).1353.检查文件或文件夹是否存在(DIR 函数)1364.获得文件修改的日期和时间(FILEDATETIME 函数).1375.获得文件大小(FILELEN 函数).1386.返回和设置文件属性(GETATTR 函数和 SETATTR 函数).1387.更改缺省文件夹或驱动器(CHDIR 语句和 CHDRIVE 语句).1398.创建和删除文件夹(MKDIR 语句和 RMDIR 语句)1409.复制文件(FILECOPY 语句)14010.删除文件(KILL 语句)14
13、211.从文件读取和写入数据(INPUT/OUTPUT).14212.文件访问类型.14213.使用顺序文件.14314.读取储存于顺序文件里的数据.14315.逐行读取文件.14316.从顺序文件中读取字符.14417.读取分隔文本文件.14518.往顺序文件里写数据.14619.使用 WRITE#和 PRINT#语句14720.操作随机文件.14821.创建用户定义的数据类型.148Excel_VBA_编程教程(2010 新春版)http:/22.操作二进制文件.15223.操作文件和文件夹的时髦方法.15324.使用 WSH 获取文件信息 .155-页面 6-25.FILESYSTEMO
14、BJEC 的方法和属性15626.对象 FILE 的属性16027.文件夹对象属性.16128.驱动器对象属性.16129.使用 WSH 创建文本文件 .16230.使用 WSH 进行其它操作 .16431.运行其它应用程序.16432.创建快捷方式.16533.接下来 .166第九章利用 VBA 控制其它应用程序.1671.启动应用程序.1672.在应用程序之间切换.1693.控制其它应用程序.1704.控制应用程序的其它方法.1715.了解自动控制.1726.了解链接和嵌入.1727.使用 VBA 进行链接和嵌入.1738.COM 和自动控制 .1749.了解绑定.17410.后期绑定 .
15、17411.早期绑定 .17412.建立到对象库的引用.17513.创建自动控制对象.17614.使用 CREATEOBJECT 函数.17615.使用自动控制创建一个新的 WORD 文档.17716.使用 GETOBJECT 函数17717.打开存在的 WORD 文档17818.使用关键字 NEW17919.使用自动控制访问 MICROSOFTOUTLOOK.18020.接下来 .181第十章对话框和自定义窗体1811.文件打开和另存为对话框.1832.GETOPENFILENAME 和 GETSAVEASFILENAME 方法.1873.创建窗体.188Excel_VBA_编程教程(201
16、0 新春版)http:/4.创建用户窗体的工具.1905.标签.1916.文字框.1917.框架.1918.选项按钮.1919.复选框.19210.切换按钮 .19211.列表框 .19212.复合框 .19213.滚动条 .19214.旋转按钮 .19215.图像 .19216.多页控件 .19217.TABSTRIP 控件.19318.REFEDIT 控件.19319.在窗体上放置控件.19320.应用程序示例 1:信息调查 19321.在窗体上添加按钮、选项框和其它控件.194-页面 7-22.更改控件名称.19723.设置其它控件属性.19724.准备工作表以储存窗体数据.19825.
17、显示自定义窗体.19926.设置 TAB 顺序 19927.了解窗体和控件事件.20028.编写 VBA 过程对窗体和控件事件反应.20129.编写过程来初始化窗体.20130.编写过程填充列表框控件.20331.编写过程控制选项按钮.20332.编写过程同步文字框和旋转按钮.20433.编写过程关闭用户窗体.20434.转移窗体数据到工作表.20535.使用 INFOSURVEY 应用程序 .20636.应用程序示例 2:学生和考试 20637.使用多页和 TABSTRIP 控件20638.给窗体 STUDENTSANDEXAMS 自定义窗体编写 VBA 过程 20839.使用自定义窗体 S
18、TUDENTSANDEXAMS.21240.接下来 .214第十一章自定义集合和类模块2141.使用集合.214Excel_VBA_编程教程(2010 新春版)http:/2.声明自定义集合.2153.给自定义集合添加对象.2154.从自定义集合移出对象.2165.创建自定义对象.2176.创建类.2187.变量声明.2188.定义类的属性.2189.创建 PROPERTYGET 过程.21910.创建 PROPERTYLET 过程.21911.创建类方法.22012.创建类的示例.22013.类模块里的事件过程.22114.创建用户界面.22115.观察 VBA 过程的执行.22916.接下
19、来 .231第十二章使用 VBA 创建自定义菜单和工具栏.2311.工具栏.2322.创建自定义工具栏.2333.删除自定义工具栏.2354.使用 COMMANDBAR 的属性2355.使用 COMMANDBAR 控件2356.理解和使用控件属性.2377.控件方法.2398.使用菜单.2409.菜单编程.24110.创建子菜单.24311.修改内置快捷菜单.24412.创建快捷菜单.24713.接下来 .249第十三章调试 VBA 过程和处理错误.249-页面 8-1.测试 VBA 过程.2492.终止过程.2493.使用断点.2504.在中断模式下使用立即窗口.2535.使用 STOP 语
20、句 2546.添加监视表达式.2547.清除监视表达式.2568.使用快速监视.256Excel_VBA_编程教程(2010 新春版)http:/9.使用本地窗口和调用堆栈对话框.25710.逐句运行 VBA 过程.25811.逐句运行过程.25912.逐过程执行过程.25913.设置下一条语句.26014.显示下一条语句.26015.终止和重新设置 VBA 过程.26016.了解和使用条件编译.26017.操纵书签 .26218.捕捉错误 .26217.接下来 .266第十四章微软 EXCEL2002 中的事件编程.2661.事件过程介绍.2662.激活和失活事件.2673.事件次序.268
21、4.工作表事件.2685.工作簿事件.2726.图表事件.2827.内嵌图表事件.2848.可为应用软件对象识别的事件.2859.查询表时间.28810.接下来 .289第十五章在 EXCEL 里使用 ACCESS2891.对象库.2892.建立对对象库的引用.2923.链接到 ACCESS.2934.使用 AUTOMATION 链接到 ACCESS 数据库.2935.使用 DAO 链接到 ACCESS 数据库.2956.使用 ADO 链接到 ACCESS 数据库.2957.从 EXCEL 执行 ACCESS 任务.2968.创建新 ACCESS 数据库.2969.打开 ACCESS 窗体.2
22、9810.打开 ACCESS 报表.30011.运行 ACCESS 查询.30112.运行选择查询.30213.运行参数查询.30314.调用 ACCESS 函数.30415.获取 ACCESS 数据到 EXCEL 工作表.30416.使用 GETROWS 方法获取数据.30417.使用 COPYFROMRECORDSET 方法获取数据.305Excel_VBA_编程教程(2010 新春版)http:/18.使用 TRANSFERSPREADSHEET 方法获取数据30619.使用 OPENDATABASE 方法.30720.从 ACCESS 数据创建文本文件 .30921.从 ACCESS
23、数据创建查询表 .310-页面 9-22.在 EXCEL 里使用 ACCESS 数据 .31123.用 ACCESS 数据创建内嵌图表 .31124.传输 EXCEL 电子表格到 ACCESS 数据库.31325.将 EXCEL 电子表格链接到 ACCESS 数据库.31326.将 EXCEL 电子表格导入 ACCESS 数据库.31427.放置 EXCEL 数据到 ACCESS 表中.31428.接下来 .316-页面 10-VBA 语言基础橄榄树整理一、VBA 语言基础第一节标识符一定义标识符是一种标识变量、常量、过程、函数、类等语言构成单位的符号,利用它可以完成对变量、常量、过程、函数、
24、类等的引用。二命名规则1)字母打头,由字母、数字和下划线组成,如 A987b_23Abc2)字符长度小于 40, (Excel2002 以上中文版等,可以用汉字且长度可达 254 个字符)3)不能与 VB 保留字重名,如 public,private,dim,goto,next,with,integer,single等第二节运算符定义:运算符是代表 VB 某种运算功能的符号。1)赋值运算符2)数学运算符2.过程名参数 1,参数 24Excel_VBA_编程教程(2010 新春版)http:/-页面 14-VBA 语言基础橄榄树整理debug.printx1,y1结果是 12、112,y1 按地
25、址传递改变了值,而 x1 按值传递,未改变原值Endsub二Function 函数函数实际是实现一种映射,它通过一定的映射规则,完成运算并返回结果。参数传递也两种:按值传递(ByVal)和按地址传递 (ByRef)。如下例:Functionpassword(ByValxasinteger,byrefyasinteger)asbooleanIfy=100theny=x+yelsey=x-yx=x+100ify=150thenpassword=trueelsepassword=falseEndFunctionSubcall_password()Dimx1asintegerDimy1asintege
26、rx1=12y1=100ifpasswordthen调用函数:1.作为一个表达式放在= 右端;2.作为参数使用debug.printx1endifEndsub三Property 属性过程和 Event 事件过程这是 VB 在对象功能上添加的两个过程,与对象特征密切相关,也是 VBA 比较重要组成,技术比较复杂,可以参考相关书籍。第十二节内部函数在 VBA 程序语言中有许多内置函数,可以帮助程序代码设计和减少代码的编写工作。一测试函数IsNumeric(x)是否为数字, 返回 Boolean 结果,TrueorFalseIsDate(x)是否是日期,返回 Boolean 结果,TrueorFal
27、seIsEmpty(x) 是否为 Empty,返回 Boolean 结果,TrueorFalseIsArray(x)指出变量是否为一个数组。IsError(expression)指出表达式是否为一个错误值IsNull(expression)指出表达式是否不包含任何有效数据(Null)。IsObject(identifier)指出标识符是否表示对象变量二数学函数Sin(X)、Cos(X)、 Tan(X)、Atan(x)三角函数,单位为弧度Log(x)返回 x 的自然对数Exp(x)返回 exExcel_VBA_编程教程(2010 新春版)http:/Abs(x)返回绝对值Int(number)、
28、Fix(number)都返回参数的整数部分,区别:Int 将-8.4 转换成-9 ,而 Fix 将-8.4 转换成 -8Sgn(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)计算
29、string 长度Left(string,x)取 string 左段 x 个字符组成的字符串Right(string,x)取 string 右段 x 个字符组成的字符串Mid(string,start,x)取 string 从 start 位开始的 x 个字符组成的字符串Ucase(string)转换为大写5-页面 15-VBA 语言基础橄榄树整理Lcase(string)转换为小写Space(x)返回 x 个空白的字符串Asc(string)返回一个 integer,代表字符串中首字母的字符代码Chr(charcode)返回 string,其中包含有与指定的字符代码相关的字符四转换函数CBo
30、ol(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)转换为 V
31、ariant 型Val(string)转换为数据型Str(number)转换为 String五时间函数Now 返回一个 Variant(Date),根据计算机系统设置的日期和时间来指定日期和时Excel_VBA_编程教程(2010 新春版)http:/间。Date 返回包含系统日期的 Variant(Date)。Time 返回一个指明当前系统时间的 Variant(Date)。Timer 返回一个 Single,代表从午夜开始到现在经过的秒数。TimeSerial(hour,minute,second)返回一个 Variant(Date),包含具有具体时、分、秒的时间。DateDiff(int
32、erval,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),其值
33、为 1 到 31 之间的整数,表示一个月中的某一日Month(date)返回一个 Variant(Integer),其值为 1 到 12 之间的整数,表示一年中的某月Year(date)返回 Variant(Integer),包含表示年份的整数。Weekday(date,firstdayofweek)返回一个 Variant(Integer),包含一个整数,代表某个日期是星期几第十三节文件操作文件Dir(pathname,attributes);pathname 可选参数,用来指定文件名的字符串表达式,可能包含目录或文件夹、以及驱动器。如果没有找到 pathname,则会返回零长度字符串(“)
34、;attributes 可选参数。常数或数值表达式,其总和用来指定文件属性。如果省略,则会返回匹配 pathname 但不包含属性的文件。删除Killpathname 从磁盘中删除文件,pathname 参数是用来指定一个文件名RmDirpathname 从磁盘中删除目录,pathname 参数是用来指定一个文件夹打开OpenpathnameFormodeAccessaccesslockAs#filenumberLen=reclength能够对文件输入/输出(I/O)。pathname 必要。字符串表达式,指定文件名,该文件名可能还包括目录、文件夹及驱动器。6-页面 16-VBA 语言基础橄榄
35、树整理mode 必要。关键字,指定文件方式,有 Append、Binary、Input、Output、或 Random 方式。如果未指定方式,则以 Random 访问方式打开文件。Excel_VBA_编程教程(2010 新春版)http:/access 可选。关键字,说明打开的文件可以进行的操作,有 Read、Write 、或 ReadWrite 操作。lock 可选。关键字,说明限定于其它进程打开的文件的操作,有 Shared、LockRead、LockWrite、和 LockReadWrite 操作。filenumber 必要。一个有效的文件号,范围在 1 到 511 之间。使用 Free
36、File 函数可得到下一个可用的文件号。reclength 可选。小于或等于 32,767(字节)的一个数。对于用随机访问方式打开的文件,该值就是记录长度。对于顺序文件,该值就是缓冲字符数。说明对文件做任何 I/O 操作之前都必须先打开文件。Open 语句分配一个缓冲区供文件进行I/O 之用,并决定缓冲区所使用的访问方式。如果 pathname 指定的文件不存在,那么,在用Append、Binary、Output 、或 Random 方式打开文件时,可以建立这一文件。如果文件已由其它进程打开,而且不允许指定的访问类型,则 Open 操作失败,而且会有错误发生。如果 mode是 Binary 方
37、式,则 Len 子句会被忽略掉。重要在 Binary、Input 和 Random 方式下可以用不同的文件号打开同一文件,而不必先将该文件关闭。在 Append 和 Output 方式下,如果要用不同的文件号打开同一文件,则必须在打开文件之前先关闭该文件。读入Input#filenumber,varlist 从已打开的顺序文件中读出数据并将数据指定给变量Get#filenumber,recnumber,varname 将一个已打开的磁盘文件读入一个变量之中。写入Write#filenumber,outputlist将数据写入顺序文件Print#filenumber,outputlist将格式化
38、显示的数据写入顺序文件中Put#filenumber,recnumber,varname 将一个变量的数据写入磁盘文件中。关闭Closefilenumberlist关闭 Open 语句所打开的输入/输出(I/O)文件注意如果今后想用 Input#语句读出文件的数据,就要用 Write#语句而不用 Print#语句将数据写入文件。因为在使用 Write#时,将数据域分界就可确保每个数据域的完整性,因此可用 Input#再将数据读出来。使用 Write#还能确保任何地区的数据都被正确读出。Write与 Print#语句不同,当要将数据写入文件时, Write#语句会在项目和用来标记字符串的引号之间
39、插入逗号。Write#语句在将 outputlist 中的最后一个字符写入文件后会插入一个新行字符,即回车换行符,(Chr(13)+Chr(10)。其他文件函数LOF(filenumber)返回一个 Long,表示用 Open 语句打开的文件的大小,该大小以字节为单位。EOF(filenumber)返回一个 Integer,它包含 Boolean 值 True,表明已经到达为 Random 或顺序 Input 打开的文件的结尾。Loc(filenumber)返回一个 Long,在已打开的文件中指定当前读/写位置Seek(filenumber)返回一个 Long,在 Open 语句打开的文件中指
40、定当前的读/写位7-页面 17-VisualBASIC 程序设计网络教学橄榄树整理Excel_VBA_编程教程(2010 新春版)http:/二、VisualBASIC 程序设计网络教学第一课 VBA 是什么1.1VBA 是什么直到 90 年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得不学习一种不同的自动化语言.例如:可以用 EXCEL 的宏语言来使 EXCEL 自动化,使用 WORDBASIC 使 WORD 自动化,等等.微软决定让它开发出来的应用程序共享一种通用的自动化语言-VisualBasicForApplication(VBA),可以认为 VBA
41、 是非常流行的应用程序开发语言 VASUALBASIC 的子集.实际上 VBA 是“寄生于“VB 应用程序的版本.VBA 和 VB 的区别包括如下几个方面:1.VB 是设计用于创建标准的应用程序 ,而 VBA 是使已有的应用程序(EXCEL 等)自动化2.VB 具有自己的开发环境,而 VBA 必须寄生于已有的应用程序.3.要运行 VB 开发的应用程序,用户不必安装 VB,因为 VB 开发出的应用程序是可执行文件(*.EXE),而 VBA 开发的程序必须依赖于它的“父“应用程序,例如 EXCEL.尽管存在这些不同,VBA 和 VB 在结构上仍然十分相似.事实上,如果你已经了解了 VB,会发现学习
42、 VBA 非常快.相应的,学完 VBA 会给学习 VB 打下坚实的基础 .而且,当学会在 EXCEL 中用 VBA创建解决方案后,即已具备在 WORDACCESSOUTLOOKFOXPROPROWERPOINT 中用 VBA 创建解决方案的大部分知识.*VBA 一个关键特征是你所学的知识在微软的一些产品中可以相互转化.*VBA 可以称作 EXCEL 的“遥控器“.VBA 究竟是什么?更确切地讲 ,它是一种自动化语言, 它可以使常用的程序自动化,可以创建自定义的解决方案.此外,如果你愿意,还可以将 EXCEL 用做开发平台实现应用程序.1.2EXCEL 环境中基于应用程序自动化的优点也许你想知道
43、 VBA 可以干什么?使用 VBA 可以实现的功能包括:1.使重复的任务自动化.2.自定义 EXCEL 工具栏,菜单和界面.3.简化模板的使用.4.自定义 EXCEL,使其成为开发平台.5.创建报表.6.对数据进行复杂的操作和分析.用 EXCEL 作为开发平台有如下原因:1.EXCEL 本身功能强大,包括打印,文件处理,格式化和文本编辑.2.EXCEL 内置大量函数.3.EXCEL 界面熟悉.4.可连接到多种数据库.用其他语言开发应用程序,一半的工作是编写一些基本功能的模块,包括文件的打开和保存,打印,复制等.而用 EXCEL 作为开发平台,则由于 EXCEL 已经具备这些基本功能,你要做的只
44、是使Excel_VBA_编程教程(2010 新春版)http:/用它.1.3 录制简单的宏在介绍学习 VBA 之前,应该花几分钟录制一个宏。新术语:“宏“,指一系列 EXCEL 能够执行的 VBA 语句。以下将要录制的宏非常简单,只是改变单元格颜色。请完成如下步骤:1)打开新工作簿,确认其他工作簿已经关闭。2)选择 A1 单元格。调出“常用“工具栏。3)选择“工具“-“ 宏“-“录制新宏“。4)输入“改变颜色“ 作为宏名替换默认宏名,单击确定,注意,此时状态栏中显示“录制“,特别是“停止录制 “工具栏也显示出来。替换默认宏名主要是便于分别这些宏。宏名最多可为 255 个字符,并且必须以字母开始
45、。其中可用的字符包括:字母、数字和1-页面 18-VisualBASIC 程序设计网络教学橄榄树整理下划线。宏名中不允许出现空格。通常用下划线代表空格。5)选择“格式“的 “单元格“,选择“图案“ 选项中的红色,单击“确定“ 。6)单击“停止录制“ 工具栏按钮,结束宏录制过程。如果“停止录制 “工具栏开始并未出现,请选择 “工具“-“宏“-“停止录制“。录制完一个宏后就可以执行它了。1.4 执行宏当执行一个宏时,EXCEL 按照宏语句执行的情况就像 VBA 代码在对 EXCEL 进行“遥控“。但VBA 的“遥控“不仅能使操作变得简便,还能使你获得一些使用 EXCEL 标准命令所无法实现的功能。
46、而且,一旦熟悉了 EXCEL 的“遥控“ ,你都会奇怪自己在没有这些“遥控“的情况下,到底是怎么熬过来的。要执行刚才录制的宏,可以按以下步骤进行:1)选择任何一个单元格,比如 A3。2)选择“工具“-“宏“-“宏“ ,显示“ 宏“对话框。3)选择“改变颜色 “,选择“执行“,则 A3 单元格的颜色变为红色。试着选择其它单元格和几个单元格组成的区域,然后再执行宏,以便加深印象。1.5 查看录制的代码到底是什么在控制 EXCEL 的运行呢?你可能有些疑惑. 好,让我们看看 VBA 的语句吧.1)选择“工具“-“宏“-“宏“ ,显示“ 宏“对话框。2)单击列表中的“ 改变颜色“,选择“编辑“按钮。此时,会打开 VBA 的编辑器窗口(VBE) 。关于该编辑器,以后再详细说明,先将注意力集Excel_VBA_编程教程(2010 新春版)http:/中到显示的代码上。代码如下:(日期和姓名会有不同)Sub 改变颜色 ()改变颜色 Macroxw 记录的宏