1、Excel_VBA_编程教程第 1 页 共 548 页Excel_VBA_编程教程第 2 页 共 548 页目录一、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打开6Excel_VBA_编程教程第 3 页 共 548
2、 页读入7写入7关闭7其他文件函数7二、VISUALBASIC 程序设计网络教学 .1第一课 VBA 是什么.11.1VBA 是什么11.2EXCEL 环境中基于应用程序自动化的优点11.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 小结5第三课学习控件.53.1EXCEL 开发
3、过程简介53.2 认识不同的控件53.3 向工作表添加控件6Excel_VBA_编程教程第 4 页 共 548 页3.4 设置控件的特性63.5 给控件命名63.6 使用用户窗体63.7 疑难解答7第四课理解变量和变量的作用74.1 代码存在的位置:模块74.2 对模块的概览74.2.1 创建过程84.2.2 运行宏94.3 保存对模块所做的改变94.4 变量94.4.1 变量的数据类型94.4.2 用 Dim 语句创建变量(声明变量 )104.4.3 变量命名的惯例.104.4.4 使用数组.104.4.5 变量赋值.11第五课利用 VBA 设置工作表使用权限.111使用 WITH 语句。2
4、使用对象变量。.方法 3:减少对象的激活和选择方法 4:关闭屏幕更新第六课提高 EXCEL 中 VBA 的效率12方法 1:尽量使用 VBA 原有的属性、方法和 WORKSHEET 函数12方法 2:尽量减少使用对象引用,尤其在循环中.121使用 With 语句。 122使用对象变量。123在循环中要尽量减少对象的访问。13方法 3:减少对象的激活和选择13方法 4:关闭屏幕更新13Excel_VBA_编程教程第 5 页 共 548 页第七课如何在 EXCEL 里使用定时器 .13三、学习微软 EXCEL2002VBA 编程和 XML,ASP 技术.15第一章电子表格自动化简介和了解宏命令.1
5、51 了解宏152 宏命令的普通应用153 写宏之前的计划164 录制宏175 运行宏186 修改宏代码197 添加注释218 分析宏代码229 清除宏代码2310 测试修改好的宏2411 两个层面运行宏的方法2412 完善你的宏代码2513 重新命名宏2714 运行宏的其它方法2715 使用键盘快捷键运行宏2716 通过菜单运行宏2817 通过工具栏按钮运行宏3018 通过工作表里面的按钮运行宏3119 保存宏3220 打印宏3221 保存宏在个人宏工作簿3222 打开含有宏的工作簿3423VB 编辑窗口.3524 了解工程浏览窗口3525 了解属性窗口3626 了解代码窗口3627VB 编
6、辑器里的其它窗口38Excel_VBA_编程教程第 6 页 共 548 页28 接下来39第二章 VBA 第一步391 了解指令,模块和过程392VBA 工程命名393 模块重命名404 从其它工程调用过程415 了解对象,属性和方法426 学习对象,属性和方法437 句法和文法458 打断很长的 VBA 语句479 了解 VBA 错误4710 查找帮助4911 语法和编程快捷助手5012 属性/方法列表 5113 常数列表5114 参数信息5215 快速信息5216 自动完成关键字5217 缩进/凸出5318 设置注释块/解除注释块5319 使用对象浏览器5320 使用 VBA 对象库582
7、1 用对象浏览器来定位过程5922 使用立即窗口5923 获取立即窗口里的信息6124 学习对象6225 电子表格单元格操作6226 使用 RANGE 属性6227 使用 CELLS 属性 62Excel_VBA_编程教程第 7 页 共 548 页28 使用 OFFSET 属性6329 选择单元格的其它方法6430 选择行和列6431 获取工作表信息6532 往工作表输入数据6533 返回工作表中的信息6534 单元格格式6635 移动,复制和删除单元格6636 操作工作簿和工作表6737 操作窗口(WINDOWS).6738 管理 EXCEL 应用程序6839 接下来68第三章了解变量,数据
8、类型和常量.691 保存 VBA 语句的结果692 变量是什么693 数据类型694 如何产生变量705 如何声明变量716 明确变量的数据类型727 变量赋值738 强制声明变量759 了解变量范围7610 过程级别(当地)变量7611 模块级别变量7712 工程级别变量7713 变量的存活期7814 了解和使用静态变量7815 声明和使用对象变量79Excel_VBA_编程教程第 8 页 共 548 页16 使用明确的对象变量8017 查找变量定义8018 在 VB 过程里面使用常量8019 内置常量8120 接下来82第四章 VBA 过程:子程序和函数821.关于函数过程.822.创建函
9、数过程.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 语句 .1033.基于多于一个条件的决定.105Excel_VB
10、A_编程教程第 9 页 共 548 页4.THEIFTHENELSE 语句.1065.IFTHENELSEIF 语句1086.嵌套的 IFTHEN 语句.1107.SELECTCASE 语句.1108.和 CASE 子句一起使用 IS.1129.确定 CASE 子句里数值的范围11310.在 CASE 子句里确定多个表达式.11411.接下来.114第六章在 VBA 中重复操作.1141.DOLOOPS:DOWHILE 和 DOUNTIL1142.观察过程执行.1173.WHILEWEND 循环1184.FORNEXT 循环 .1195.FOREACHNEXT 循环.1207.提前跳出循环.1
11、218.循环嵌套.1229.接下来.122第七章利用 VBA 数组管理数据清单和表格1221.了解数组.1232.声明数组.1243.数组的上界和下界.1244.在 VBA 过程里使用数组.1245.数组和循环语句.1256.使用二维数组.1277.静态和动态数组.1288.数组函数.1299.ARRAY 函数.13010.ISARRAY 函数.130Excel_VBA_编程教程第 10 页 共 548 页11.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 语句)14211.从文件读
13、取和写入数据(INPUT/OUTPUT).14212.文件访问类型.14213.使用顺序文件.14314.读取储存于顺序文件里的数据.14315.逐行读取文件.14316.从顺序文件中读取字符.14417.读取分隔文本文件.14518.往顺序文件里写数据.14619.使用 WRITE#和 PRINT#语句14720.操作随机文件.14821.创建用户定义的数据类型.14822.操作二进制文件.15223.操作文件和文件夹的时髦方法.153Excel_VBA_编程教程第 11 页 共 548 页24.使用 WSH 获取文件信息.15525.FILESYSTEMOBJEC 的方法和属性 15626
14、.对象 FILE 的属性16027.文件夹对象属性.16128.驱动器对象属性.16129.使用 WSH 创建文本文件.16230.使用 WSH 进行其它操作.16431.运行其它应用程序.16432.创建快捷方式.16533.接下来.166第九章利用 VBA 控制其它应用程序.1671.启动应用程序.1672.在应用程序之间切换.1693.控制其它应用程序.1704.控制应用程序的其它方法.1715.了解自动控制.1726.了解链接和嵌入.1727.使用 VBA 进行链接和嵌入.1738.COM 和自动控制.1749.了解绑定.17410.后期绑定.17411.早期绑定.17412.建立到对
15、象库的引用.17513.创建自动控制对象.17614.使用 CREATEOBJECT 函数.17615.使用自动控制创建一个新的 WORD 文档.17716.使用 GETOBJECT 函数17717.打开存在的 WORD 文档178Excel_VBA_编程教程第 12 页 共 548 页18.使用关键字 NEW17919.使用自动控制访问 MICROSOFTOUTLOOK.18020.接下来.181第十章对话框和自定义窗体1811.文件打开和另存为对话框.1832.GETOPENFILENAME 和 GETSAVEASFILENAME 方法.1873.创建窗体.1884.创建用户窗体的工具.1
16、905.标签.1916.文字框.1917.框架.1918.选项按钮.1919.复选框.19210.切换按钮.19211.列表框.19212.复合框.19213.滚动条.19214.旋转按钮.19215.图像.19216.多页控件.19217.TABSTRIP 控件.19318.REFEDIT 控件 .19319.在窗体上放置控件.19320.应用程序示例 1:信息调查19321.在窗体上添加按钮、选项框和其它控件.19422.更改控件名称.19723.设置其它控件属性.19724.准备工作表以储存窗体数据.198Excel_VBA_编程教程第 13 页 共 548 页25.显示自定义窗体.19
17、926.设置 TAB 顺序19927.了解窗体和控件事件.20028.编写 VBA 过程对窗体和控件事件反应.20129.编写过程来初始化窗体.20130.编写过程填充列表框控件.20331.编写过程控制选项按钮.20332.编写过程同步文字框和旋转按钮.20433.编写过程关闭用户窗体.20434.转移窗体数据到工作表.20535.使用 INFOSURVEY 应用程序 .20636.应用程序示例 2:学生和考试20637.使用多页和 TABSTRIP 控件20638.给窗体 STUDENTSANDEXAMS 自定义窗体编写 VBA 过程20839.使用自定义窗体 STUDENTSANDEXA
18、MS.21240.接下来.214第十一章自定义集合和类模块2141.使用集合.2142.声明自定义集合.2153.给自定义集合添加对象.2154.从自定义集合移出对象.2165.创建自定义对象.2176.创建类.2187.变量声明.2188.定义类的属性.2189.创建 PROPERTYGET 过程.21910.创建 PROPERTYLET 过程.21911.创建类方法.220Excel_VBA_编程教程第 14 页 共 548 页12.创建类的示例.22013.类模块里的事件过程.22114.创建用户界面.22115.观察 VBA 过程的执行 .22916.接下来.231第十二章使用 VBA
19、 创建自定义菜单和工具栏.2311.工具栏.2322.创建自定义工具栏.2333.删除自定义工具栏.2354.使用 COMMANDBAR 的属性 2355.使用 COMMANDBAR 控件2356.理解和使用控件属性.2377.控件方法.2398.使用菜单.2409.菜单编程.24110.创建子菜单.24311.修改内置快捷菜单.24412.创建快捷菜单.24713.接下来.249第十三章调试 VBA 过程和处理错误.2491.测试 VBA 过程.2492.终止过程.2493.使用断点.2504.在中断模式下使用立即窗口.2535.使用 STOP 语句2546.添加监视表达式.2547.清除监
20、视表达式.256Excel_VBA_编程教程第 15 页 共 548 页8.使用快速监视.2569.使用本地窗口和调用堆栈对话框.25710.逐句运行 VBA 过程.25811.逐句运行过程.25912.逐过程执行过程.25913.设置下一条语句.26014.显示下一条语句.26015.终止和重新设置 VBA 过程.26016.了解和使用条件编译.26017.操纵书签.26218.捕捉错误.26217.接下来.266第十四章微软 EXCEL2002 中的事件编程.2661.事件过程介绍.2662.激活和失活事件.2673.事件次序.2684.工作表事件.2685.工作簿事件.2726.图表事件
21、.2827.内嵌图表事件.2848.可为应用软件对象识别的事件.2859.查询表时间.28810.接下来.289第十五章在 EXCEL 里使用 ACCESS2891.对象库.2892.建立对对象库的引用.292Excel_VBA_编程教程第 16 页 共 548 页3.链接到 ACCESS.2934.使用 AUTOMATION 链接到 ACCESS 数据库.2935.使用 DAO 链接到 ACCESS 数据库.2956.使用 ADO 链接到 ACCESS 数据库.2957.从 EXCEL 执行 ACCESS 任务.2968.创建新 ACCESS 数据库.2969.打开 ACCESS 窗体.29
22、810.打开 ACCESS 报表.30011.运行 ACCESS 查询.30112.运行选择查询.30213.运行参数查询.30314.调用 ACCESS 函数.30415.获取 ACCESS 数据到 EXCEL 工作表.30416.使用 GETROWS 方法获取数据.30417.使用 COPYFROMRECORDSET 方法获取数据.30518.使用 TRANSFERSPREADSHEET 方法获取数据30619.使用 OPENDATABASE 方法.30720.从 ACCESS 数据创建文本文件.30921.从 ACCESS 数据创建查询表.31022.在 EXCEL 里使用 ACCESS
23、 数据.31123.用 ACCESS 数据创建内嵌图表.31124.传输 EXCEL 电子表格到 ACCESS 数据库.31325.将 EXCEL 电子表格链接到 ACCESS 数据库.31326.将 EXCEL 电子表格导入 ACCESS 数据库.31427.放置 EXCEL 数据到 ACCESS 表中.31428.接下来.316VBA 语言基础橄榄树整理一、VBA 语言基础Excel_VBA_编程教程第 17 页 共 548 页第一节标识符一定义标识符是一种标识变量、常量、过程、函数、类等语言构成单位的符号,利用它可以完成对变量、常量、过程、函数、类等的引用。二命名规则1)字母打头,由字母
24、、数字和下划线组成,如 A987b_23Abc2)字符长度小于 40, (Excel2002 以上中文版等,可以用汉字且长度可达 254 个字符)3)不能与 VB 保留字重名,如 public,private,dim,goto,next,with,integer,single 等第二节运算符定义:运算符是代表 VB 某种运算功能的符号。1)赋值运算符2)数学运算符2.过程名参数 1,参数 24-页面 14-VBA 语言基础橄榄树整理debug.printx1,y1结果是 12、112,y1 按地址传递改变了值,而 x1 按值传递,未改变原值Endsub二Function 函数函数实际是实现一种
25、映射,它通过一定的映射规则,完成运算并返回结果。参数传递也两种:按值传递(ByVal) 和按地址传递(ByRef) 。如下例:Excel_VBA_编程教程第 25 页 共 548 页Functionpassword(ByValxasinteger,byrefyasinteger)asbooleanIfy=100theny=x+yelsey=x-yx=x+100ify=150thenpassword=trueelsepassword=falseEndFunctionSubcall_password()Dimx1asintegerDimy1asintegerx1=12y1=100ifpasswor
26、dthen调用函数:1.作为一个表达式放在=右端;2.作为参数使用debug.printx1endifEndsub三Property 属性过程和 Event 事件过程这是 VB 在对象功能上添加的两个过程,与对象特征密切相关,也是 VBA 比较重要组成,技术比较复杂,可以参考相关书籍。第十二节内部函数在 VBA 程序语言中有许多内置函数,可以帮助程序代码设计和减少代码的编写工作。一测试函数IsNumeric(x)是否为数字,返回 Boolean 结果,TrueorFalseIsDate(x)是否是日期 ,返回 Boolean 结果,TrueorFalseIsEmpty(x) 是否为 Empty
27、,返回 Boolean 结果,TrueorFalseIsArray(x)指出变量是否为一个数组。IsError(expression)指出表达式是否为一个错误值IsNull(expression)指出表达式是否不包含任何有效数据(Null)。IsObject(identifier)指出标识符是否表示对象变量二数学函数Excel_VBA_编程教程第 26 页 共 548 页Sin(X)、Cos(X)、Tan(X)、Atan(x)三角函数,单位为弧度Log(x)返回 x 的自然对数Exp(x)返回 exAbs(x)返回绝对值Int(number)、Fix(number)都返回参数的整数部分,区别:
28、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)计算 string 长度Left(string,x)取 s
29、tring 左段 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,代表字符串中首字母的字符代码Excel_VBA_编程教程第 27 页 共 548 页Chr(charcode)返回 string,其中包含有与指定的字符代码相关的字符四转换函数C
30、Bool(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)转换为
31、 Variant 型Val(string)转换为数据型Str(number)转换为 String五时间函数Now 返回一个 Variant(Date),根据计算机系统设置的日期和时间来指定日期和时间。Date 返回包含系统日期的 Variant(Date)。Time 返回一个指明当前系统时间的 Variant(Date)。Timer 返回一个 Single,代表从午夜开始到现在经过的秒数。TimeSerial(hour,minute,second)返回一个 Variant(Date),包含具有具体时、分、秒的时间。DateDiff(interval,date1,date2,firstdayof
32、week,firstweekofyear)返回 Variant(Long)的值,表示两个指定日期间的时间间隔数目Second(time)返回一个 Variant(Integer),其值为 0 到 59 之间的整数,表示一分钟之中的某个秒Minute(time)返回一个 Variant(Integer),其值为 0 到 59 之间的整数,表示一小时中的某分钟Hour(time)返回一个 Variant(Integer),其值为 0 到 23 之间的整数,表示一天之中的某Excel_VBA_编程教程第 28 页 共 548 页一钟点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 方式。Excel_VBA_编程教程第 29 页 共 548 页如果未指定方式,则以 Random 访问方式打开文件。access 可选。关键字,说明打开的文件可以进行的操作,有 Read、Write、或 ReadWrite 操作。lock 可选。关键字,说明限定于其它进程打开的文件的操作,有 Shared、LockRead、LockWrite、和 LockReadWrite 操作。filenumber 必要。一个有效的文件号,范围在 1 到 511 之间。使用 FreeF
36、ile 函数可得到下一个可用的文件号。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 中的最后一个字符写入文件后会插入一个新Excel_VBA_编程教程第 30 页 共 548 页行字符,即回车换行符,(Chr(13)+Chr(10) 。其他文件函数LOF(filenumber)返回一个 Long,表示用 Open 语句打开的文件的大小,该大小以字节为单位。EOF(filenumber)返回一个 Integer,它包含 Boolean 值 True,表明已经到达为 Random 或顺序 Input 打开的文件的结尾。Loc(filenumber)返回一个 Long,在已打开的文件中指定当前读/ 写位置Seek(filenum
40、ber)返回一个 Long,在 Open 语句打开的文件中指定当前的读 /写位7-页面 17-VisualBASIC 程序设计网络教学橄榄树整理二、VisualBASIC 程序设计网络教学第一课 VBA 是什么1.1VBA 是什么直到 90 年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得不学习一种不同的自动化语言.例如:可以用 EXCEL 的宏语言来使 EXCEL 自动化,使用 WORDBASIC 使 WORD 自动化,等等.微软决定让它开发出来的应用程序共享一种通用的自动化语言-VisualBasicForApplication(VBA),可以认为 VBA 是非常流行的应用程序开发语言 VASUALBASIC 的子集. 实际上 VBA 是“寄生于“VB 应用程序的版本 .VBA 和 VB 的区别包括如下几个方面:1.VB 是设计用于创建标准的应用程序,而 VBA 是使已有的应用程序(EXCEL 等)自动化