《Excel编程实例(170例~).doc》由会员分享,可在线阅读,更多相关《Excel编程实例(170例~).doc(97页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、|Excel 编程实例(170 例)主要内容和特点ExcelVBA 编程入门范例 主要是以一些基础而简短的 VBA 实例来对ExcelVBA 中的常用对象及其属性和方法进行讲解,包括应用程序对象、窗口、工作簿、工作表、单元格和单元格区域、图表、数据透视表、形状、控件、菜单和工具栏、帮助助手、格式化操作、文件操作、以及常用方法和函数及技巧等方面的应用示例。这些例子都比较基础,很容易理解,因而,很容易调试并得以实现,让您通过具体的实例来熟悉 ExcelVBA 编程。 分 16 章共 14 个专题,以具体实例来对大多数常用的 ExcelVBA 对象进行讲解; 一般而言,每个实例都很简短,用来说明使用
2、 VBA 实现 Excel 某一功能的操作; 各章内容主要是实例,即 VBA 代码,配以简短的说明,有些例子可能配以必要的图片,以便于理解; 您可以对这些实例进行扩充或组合,以实现您想要的功能或更复杂的操作。VBE 编辑器及 VBA 代码输入和调试的基本知识在学习这些实例的过程中,最好自已动手将它们输入到 VBE 编辑器中调试运行,来查看它们的结果。当然,您可以偷赖,将它们复制/粘贴到代码编辑窗口后,进行调试运行。下面,对 VBE 编辑器界面进行介绍,并对 VBA 代码输入和调试的基本知识进行简单的讲解。激活 VBE 编辑器一般可以使用以下三种方式来打开 VBE 编辑器: 使用工作表菜单“工具
3、宏Visual Basic 编辑器”命令,如图 00-01所示; 在 Visual Basic 工具栏上,按“Visual Basic 编辑器 ”按钮,如图 00-02 所示; 按 Alt+F11 组合键。|图 00-01:选择菜单“工具 宏Visual Basic 编辑器”命令来打开 VBE编辑器图 00-02:选择 Visual Basic 工具栏上的“Visual Basic 编辑器”命令按钮来打开 VBE 编辑器此外,您也可以使用下面三种方式打开 VBE 编辑器: 在任一工作表标签上单击鼠标右键,在弹出的菜单中选择“查看代码” ,则可进入 VBE 编辑器访问该工作表的代码模块,如图 0
4、0-03 所示; 在工作簿窗口左上角的 Excel 图标上单击鼠标右键,在弹出的菜单中选择“查看代码” ,则可进入 VBE 编辑器访问活动工作簿的 ThisWorkbook 代码模块,如图 00-04 所示; 选择菜单“工具宏宏”命令打开宏对话框,若该工作簿中有宏程序,则单击该对话框中的“编辑”按钮即可进行 VBE 编辑器代码模块,如图00-05 所示。|图 00-03:右击工作表标签弹出菜单并选择 “查看代码 ”打开 VBE 编辑器图 00-04:右击 Excel 图标弹出菜单并选择“查看代码”打开 VBE 编辑器图 00-05:在宏对话框中单击 “编辑”按钮打开 VBE 编辑器VBE 编辑
5、器窗口简介刚打开 VBE 编辑器时,所显示的窗口如图 00-06 所示,其中没有代码模块窗口。|图 00-06:刚打开 VBE 编辑器时的窗口可以在“工程资源管理器”中双击任一对象打开代码窗口,或者选择菜单“插入模块”或“插入类模块”来打开代码窗口。一般 VBE 编辑器窗口及各组成部件名称如图 00-07 所示,可以通过“视图 ”菜单中的菜单项选择所出现的窗口。同时,可以在“工程属性”窗口中设置或修改相应对象的属性。|图 00-07:VBE 编辑器窗口下面是带有用户窗体的 VBE 编辑器窗口,如图 00-08 所示。选择 VBE 菜单|“插入用户窗体” ,即可插入一个用户窗体。当插入用户窗体后
6、,在“工程资源管理器”窗口中会出现一个用户窗体对象, “工程属性”窗口显示当前用户窗体的属性,可对相关属性进行设置或修改。同时,在用户窗体上用鼠标单击,会出现“控件工具箱” 。在“工程资源管理器”窗口双击用户窗体图标,会出现相应的用户窗体;在用户窗体图标或者是在用户窗体上单击鼠标右键,然后在弹出的菜单中选择“查看代码” ,则会出现用户窗体代码窗口。|图 00-08:VBE 编辑器窗口(带有用户窗体)在 VBE 编辑器中输入 VBA 代码如前所述,您可以选择 VBE 菜单“插入用户窗体/模块/ 类模块”来插入模块或用户窗体以及相应的代码窗口。此外,您也可以在“工程资源管理器”中单击鼠标右键,从弹
7、出的菜单中选择“插入用户窗体/模块/ 类模块”来实现上面的操作。在获取相应的代码模块窗口后,就可以输入 VBA 代码了。在 VBE 编辑器的代码模块中输入 VBA 代码,通常有以下几种方法: 手工键盘输入; 使用宏录制器,即选择菜单“工具宏录制新宏 ”命令,将所进行的操作自动录制成宏代码; 复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中; 导入代码模块,即在 VBE 编辑器中选择菜单“文件导入文件”或在“工程资源管理器”的任一对象上右击鼠标选择菜单“导入文件” ,选择相应的代码文件导入。如果不想要某个模块了,可以选择菜单“文件移除模块” ,也可以在相应的模块上单击鼠标右键,从弹出
8、的菜单中选择“移除模块” 。此时,会弹出一个警告框,询问在移除模块前是否将其导出,可以根据需要进行选择。也可以选择菜单“文件导出文件”或在相应的模块上单击鼠标右键后,从弹出的菜单中选择“导出文件” ,将移除的模块保存在相应的文件夹中。这样,以后可以对其进行导入,从而加以利用。调试 VBA 代码在 VBE 编辑器的菜单中,有两项与调试运行有关的菜单项,即“调试”菜单和“运行”菜单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常用到的有以下几个: 逐语句。可以按 F8 键对代码按顺序一条一条语句运行,从而找出语句或逻辑错误。 设置断点。在可能存在问题的语句处设置断点(可通过在相应代码
9、前的空白部位单击,将会出现一个深红色的椭圆即断点),当程序运行至断点处时,会中止运行。 在语句的适当部位设置 Debug.Print 语句,运行后其结果会显示在“立即窗口”中,可以此测试或跟踪变量的值。 在“立即窗口”中测试。对值的测试或跟踪,也可以以 “?”开头,在“立即窗口”中输入需要测试值的语句,按 Enter 回车键后将立即出现结果;对执行语句的测试,可直接在“立即窗口”中输入,按 Enter 回车键后将执行。 可以按 F5 键直接运行光标所在位置的子程序。在执行程序后,必须在 Excel 工作表中查看所得到的结果。可以用鼠标单击VBE 编辑器左上角的 Excel 图标或者是按 Alt
10、+F11 组合键切换到 Excel 界面。(当然,对程序代码的调试有很多方法和技巧,留待以后对 VBA 进一步研究和理解更透彻后一并讨论。)利用 VBA 帮助系统如果遇到疑问或错误,可以利用 Excel 自带的 VBA 帮助系统。 可以在如图 00-09 所示的部位输入需要帮助的关键词,按 Enter 回车键后将会出现相关主题。用鼠标单击相应的主题即会出现详细的帮助信息。图 00-09:帮助搜索窗口| 可以按 F2 键,调出“对象浏览器”窗口(如图 00-10 所示),在搜索文本框中输入需要帮助的关键词,将会在“搜索结果”中出现一系列相关的对象及方法、属性列表,单击相应的对象则会在“类”和“成
11、员”列表框中显示相应的对象和方法、属性成员列表,在成员列表中相应的项目上按 F1 键即会出现详细的帮助信息。(“对象浏览器”是一个很好的帮助工具,值得好好研究)图 00-10:对象浏览器窗口|参考资料ExcelVBA 编程入门范例 参考或引用了以下书籍和资料:(1)Excel 2003 高级 VBA 编程宝典(2)Excel 2003 与 VBA 编程从入门到精通(中文版)(3)巧学巧用 Excel 2003 VBA 与宏(中文版)(4)ExcelVBA 应用程序专业设计实用指南(5)ExcelVBA 应用开发与实例精讲(6)一些网上资源更多的信息关于 ExcelVBA 的更多参考和学习资源,
12、可以在 上查找,有疑问也可以在 ExcelHome 论坛中提问。您也可以登录我的博客http:/,上面有很多 Excel 的学习资料。同时,欢迎与我联系交流,我的 e-mail 是:。 “学习 Excel,使用 VBA 对 Excel 进行控制操作是我很热衷的业余爱好之一。”fanjy Excel 应用程序对象 (Application 对象)及其常用方法基本操作应用示例分类:ExcelVBAExcelVBA 编程入门范例Application 对象代表整个 Microsoft Excel 应用程序,带有 175 个属性和 52 个方法,可以设置整个应用程序的环境或配置应用程序。示例 01-
13、01:体验开/关屏幕更新(ScreenUpdating 属性)Sub 关闭屏幕更新()MsgBox “顺序切换工作表 Sheet1Sheet2 Sheet3Sheet2,先开启屏幕更新,然后关闭屏幕更新“Worksheets(1).SelectMsgBox “目前屏幕中显示工作表 Sheet1“Application.ScreenUpdating = TrueWorksheets(2).SelectMsgBox “显示 Sheet2 了吗?“|Worksheets(3).SelectMsgBox “显示 Sheet3 了吗?“Worksheets(2).SelectMsgBox “下面与前面执
14、行的程序代码相同,但关闭屏幕更新功能“Worksheets(1).SelectMsgBox “目前屏幕中显示工作表 Sheet1“ & Chr(10) & “关屏屏幕更新功能“Application.ScreenUpdating = FalseWorksheets(2).SelectMsgBox “显示 Sheet2 了吗?“Worksheets(3).SelectMsgBox “显示 Sheet3 了吗?“Worksheets(2).SelectApplication.ScreenUpdating = TrueEnd Sub示例说明:ScreenUpdating 属性用来控制屏幕更新。当运行
15、一个宏程序处理涉及到多个工作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CPU 的处理时间,从而降低程序的运行速度,而关闭该属性则可显著提高程序运行速度。示例 01-02:使用状态栏 (StatusBar 属性)Sub testStatusBar()Application.DisplayStatusBar = True 开启状态栏显示赋值状态栏显示的文本Application.StatusBar = “http:/“End Sub示例说明:StatusBar 属性用来指定显示在状态栏上的信息。若不想再显示状态栏文本,可使用 Application.StatusBar = False 语句关闭状态栏显示,也可以在程序开始将原先的状态栏设置存储,如使用语句 oldStatusBar =