1、1ExcelVBA 编程实例(150 例)主要内容和特点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 组合键。2图 00-01:选择菜单“ 工具宏Visual Basic 编辑器”命令来打开 VBE 编辑器图 00-02:选择 Visual Basic 工具栏上的“Visual Basic 编辑器”命令按钮来打开VBE 编辑器此外,您也可以使用下面三种方式打开 VBE 编辑器: 在任一工作表标签上单击鼠标右键,在弹出的菜单中选择“查看代码”,则可进入 VBE 编辑器访问该工作表的代码模块,如
4、图 00-03 所示; 在工作簿窗口左上角的 Excel 图标上单击鼠标右键,在弹出的菜单中选择“查看代码” ,则可进入 VBE 编辑器访问活动工作簿的 ThisWorkbook 代码模块,如图 00-04 所示; 选择菜单“工具宏宏”命令打开宏对话框,若该工作簿中有宏程序,则单击该对话框中的“编辑”按钮即可进行 VBE 编辑器代码模块,如图 00-05所示。3图 00-03:右击工作表标签弹出菜单并选择 “查看代码”打开 VBE 编辑器图 00-04:右击 Excel 图标弹出菜单并选择“查看代码”打开 VBE 编辑器图 00-05:在宏对话框中单击 “编辑”按钮打开 VBE 编辑器VBE
5、编辑器窗口简介刚打开 VBE 编辑器时,所显示的窗口如图 00-06 所示,其中没有代码模块窗口。4图 00-06:刚打开 VBE 编辑器时的窗口可以在“工程资源管理器” 中双击任一对象打开代码窗口,或者选择菜单“插入模块”或“ 插入 类模块”来打开代码窗口。一般 VBE 编辑器窗口及各组成部件名称如图 00-07 所示,可以通过 “视图”菜单中的菜单项选择所出现的窗口。同时,可以在“工程属性” 窗口中设置或修改相应对象的属性。5图 00-07:VBE 编辑器窗口下面是带有用户窗体的 VBE 编辑器窗口,如图 00-08 所示。选择 VBE 菜单“插入用户窗体”,即可插入一个用户窗体。当插入用
6、户窗体后,在“工程资源6管理器”窗口中会出现一个用户窗体对象,“工程属性”窗口显示当前用户窗体的属性,可对相关属性进行设置或修改。同时,在用户窗体上用鼠标单击,会出现“控件工具箱” 。在“工程资源管理器” 窗口双击用户窗体图标,会出现相应的用户窗体;在用户窗体图标或者是在用户窗体上单击鼠标右键,然后在弹出的菜单中选择“查看代码” ,则会出现用户窗体代码窗口。图 00-08:VBE 编辑器窗口(带有用户窗体)在 VBE 编辑器中输入 VBA 代码7如前所述,您可以选择 VBE 菜单“插入用户窗体/模块/ 类模块”来插入模块或用户窗体以及相应的代码窗口。此外,您也可以在“工程资源管理器”中单击鼠标
7、右键,从弹出的菜单中选择“插入用户窗体/ 模块/类模块”来实现上面的操作。在获取相应的代码模块窗口后,就可以输入 VBA 代码了。在 VBE 编辑器的代码模块中输入 VBA 代码,通常有以下几种方法: 手工键盘输入; 使用宏录制器,即选择菜单“工具宏录制新宏 ”命令,将所进行的操作自动录制成宏代码; 复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中; 导入代码模块,即在 VBE 编辑器中选择菜单“文件 导入文件”或在“ 工程资源管理器”的任一对象上右击鼠标选择菜单“导入文件”,选择相应的代码文件导入。如果不想要某个模块了,可以选择菜单“文件移除模块”,也可以在相应的模块上单击鼠标右
8、键,从弹出的菜单中选择“移除模块”。此时,会弹出一个警告框,询问在移除模块前是否将其导出,可以根据需要进行选择。也可以选择菜单“文件导出文件”或在相应的模块上单击鼠标右键后,从弹出的菜单中选择“导出文件”,将移除的模块保存在相应的文件夹中。这样,以后可以对其进行导入,从而加以利用。调试 VBA 代码在 VBE 编辑器的菜单中,有两项与调试运行有关的菜单项,即“调试”菜单和“运行”菜单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常用到的有以下几个: 逐语句。可以按 F8 键对代码按顺序一条一条语句运行,从而找出语句或逻辑错误。 设置断点。在可能存在问题的语句处设置断点(可通过在相
9、应代码前的空白部位单击,将会出现一个深红色的椭圆即断点),当程序运行至断点处时,会中止运行。 在语句的适当部位设置 Debug.Print 语句,运行后其结果会显示在“立即窗口”中,可以此测试或跟踪变量的值。 在 “立即窗口” 中测试。对值的测试或跟踪,也可以以“?”开头,在“立即窗口”中输入需要测试值的语句,按 Enter 回车键后将立即出现结果;对执行语句的测试,可直接在“立即窗口”中输入,按 Enter 回车键后将执行。 可以按 F5 键直接运行光标所在位置的子程序。在执行程序后,必须在 Excel 工作表中查看所得到的结果。可以用鼠标单击 VBE 编辑器左上角的 Excel 图标或者是
10、按 Alt+F11 组合键切换到 Excel 界面。(当然,对程序代码的调试有很多方法和技巧,留待以后对 VBA 进一步研究和理解更透彻后一并讨论。)利用 VBA 帮助系统如果遇到疑问或错误,可以利用 Excel 自带的 VBA 帮助系统。 可以在如图 00-09 所示的部位输入需要帮助的关键词,按 Enter 回车键后将会出现相关主题。用鼠标单击相应的主题即会出现详细的帮助信息。图 00-09:帮助搜索窗口 可以按 F2 键,调出“对象浏览器”窗口(如图 00-10 所示),在搜索文本框中输8入需要帮助的关键词,将会在“搜索结果”中出现一系列相关的对象及方法、属性列表,单击相应的对象则会在“
11、类”和“成员” 列表框中显示相应的对象和方法、属性成员列表,在成员列表中相应的项目上按 F1 键即会出现详细的帮助信息。(“对象浏览器 ”是一个很好的帮助工具,值得好好研究)图 00-10:对象浏览器窗口参考资料ExcelVBA 编程入门范例 参考或引用了以下书籍和资料:9(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 个方法,可以设置整个应用程序的环境
13、或配置应用程序。示例 01-01:体验开/关屏幕更新(ScreenUpdating 属性)Sub 关闭屏幕更新()MsgBox “顺序切换工作表 Sheet1Sheet2Sheet3Sheet2,先开启屏幕更新,然后关闭屏幕更新“Worksheets(1).SelectMsgBox “目前屏幕中显示工作表 Sheet1“Application.ScreenUpdating = TrueWorksheets(2).SelectMsgBox “显示 Sheet2 了吗?“Worksheets(3).SelectMsgBox “显示 Sheet3 了吗?“Worksheets(2).SelectMs
14、gBox “下面与前面执行的程序代码相同,但关闭屏幕更新功能“Worksheets(1).SelectMsgBox “目前屏幕中显示工作表 Sheet1“ & Chr(10) & “关屏屏幕更新功能“Application.ScreenUpdating = False10Worksheets(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.Sta
16、tusBar = False 语句关闭状态栏显示,也可以在程序开始将原先的状态栏设置存储,如使用语句 oldStatusBar = Application.DisplayStatusBar 将状态栏原来的信息存储在变量 oldStatusBar,在程序运行完成或退出时,将变量重新赋值给状态栏,如使用语句 Application.DisplayStatusBar = oldStatusBar,以恢复状态栏原状。示例 01-03:处理光标(Cursor 属性)Sub ViewCursors()Application.Cursor = xlNorthwestArrowMsgBox “您将使用箭头光标
17、,切换到 Excel 界面查看光标形状“Application.Cursor = xlIBeamMsgBox “您将使用工形光标,切换到 Excel 界面查看光标形状“Application.Cursor = xlWaitMsgBox “您将使用等待形光标,切换到 Excel 界面查看光标形状“Application.Cursor = xlDefaultMsgBox “您已将光标恢复为缺省状态“End Sub示例 01-04:获取系统信息Sub GetSystemInfo()MsgBox “Excel 版本信息为 :“ & Application.CalculationVersionMsgBo
18、x “Excel 当前允许使用的内存为 :“ & Application.MemoryFreeMsgBox “Excel 当前已使用的内存为 :“ & Application.MemoryUsedMsgBox “Excel 可以使用的内存为 :“ & Application.MemoryTotalMsgBox “本机操作系统的名称和版本为:“ & Application.OperatingSystem11MsgBox “本产品所登记的组织名为:“ & Application.OrganizationNameMsgBox “当前用户名为:“ & Application.UserNameMsgBo
19、x “当前使用的 Excel 版本为:“ & Application.VersionEnd Sub示例说明:可以使用给 UserName 属性赋值以设置用户名称。示例 01-05:退出复制/剪切模式(CutCopyMode 属性)Sub exitCutCopyMode()Application.CutCopyMode = FalseEnd Sub示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会在原单元格区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用Application.CutCopyMode = False 语句恢复该属性的默认设置。示例 01-06:禁止弹
20、出警告信息 (DisplayAlerts 属性)Sub testAlertsDisplay()Application.DisplayAlerts = FalseEnd Sub示例说明:在程序运行过程中,有时由于 Excel 本身设置的原因,会弹出对话框,从而中断程序的运行,您可以在程序之前加上 Application.DisplayAlerts = False 语句以禁止弹出这些对话框而不影响程序正常运行。需要注意的是,在程序运行结束前,应使 DisplayAlerts 属性恢复为缺省状态,即使用语句 Application.DisplayAlerts = True。该属性的默认设置为 Tru
21、e,当将该属性设置为 False 时,Excel 会使直接使用对话框中默认的选择,从而不会因为弹出对话框而影响程序运行。示例 01-07:将 Excel 全屏幕显示Sub testFullScreen()MsgBox “运行后将 Excel 的显示模式设置为全屏幕“Application.DisplayFullScreen = TrueMsgBox “恢复为原来的状态“Application.DisplayFullScreen = FalseEnd Sub示例 01-08:Excel 启动的文件夹路径Sub ExcelStartfolder()MsgBox “Excel 启动的文件夹路径为:
22、“ & Chr(10) & Application.StartupPathEnd Sub示例 01-09:打开最近使用过的文档Sub OpenRecentFiles()MsgBox “显示最近使用过的第三个文件名,并打开该文件“MsgBox “最近使用的第三个文件的名称为:“ & Application.RecentFiles(3).Name12Application.RecentFiles(3).OpenEnd Sub示例 01-10:打开文件(FindFile 方法)Sub FindFileOpen()On Error Resume NextMsgBox “请打开文件“, vbOKOnly
23、 + vbInformation, “打开文件“If Not Application.FindFile ThenMsgBox “文件未找到“, vbOKOnly + vbInformation, “打开失败“End IfEnd Sub示例说明:本示例将显示“打开”文件对话框,若用户未打开文件(即点击“取消”按钮),则会显示“ 打开失败”信息框。示例中使用了 FindFile 方法,用来显示“打开”对话框并让用户打开一个文件。如果成功打开一个新文件,则该值为 True。如果用户取消了操作并退出该对话框,则该值为 False。示例 01-11:文件对话框操作 (FileDialog 属性)Sub
24、UseFileDialogOpen()Dim lngCount As Long开启“ 打开文件 “对话框With Application.FileDialog(msoFileDialogOpen).AllowMultiSelect = True.Show显示所选的每个文件的路径For lngCount = 1 To .SelectedItems.CountMsgBox .SelectedItems(lngCount)Next lngCountEnd WithEnd Sub示例说明:本示例显示“打开文件”对话框,当用户在其中选择一个或多个文件后,将依次显示每个文件的路径。其中,FileDialo
25、g 属性返回打开和保存对话框中一系列对象的集合,您可以对该集合对象的属性进行进一步的设置,如上例中的 AllowMultiSelect 属性设置为 True 将允许用户选择多个文件。示例 01-12:保存 Excel 的工作环境Sub 保存 Excel 的工作环境()MsgBox “将 Excel 的工作环境保存到 D:ExcelSample中“Application.SaveWorkspace “D:ExcelSampleSample“End Sub示例说明:运行本程序后,将工作簿以带后缀名.xlw 保存到 D 盘的 ExcelSample 文件夹中,生成的文件全名为 Sample.xlw。
26、当改变工作簿并保存时,Excel会询问是覆盖原文件还是保存副本。示例 01-13:改变 Excel 工作簿名字(Caption 属性)13Sub SetCaption()Application.Caption = “My ExcelBook“End Sub示例说明:运行本程序后,将工作簿左上角 Excel 图标右侧的“Microsoft Excel”改为“My ExcelBook”。示例 01-14:使用 InputBox 方法Sub SampleInputBox()Dim vInputvInput = InputBox(“请输入用户名 :“, “获取用户名 “, Application.Us
27、erName)MsgBox “您好!“ & vInput & “.很高兴能认识您.“, vbOKOnly, “打招呼“End Sub示例 01-15:设置页边距 (CentimetersToPoints 方法)Sub SetLeftMargin()MsgBox “将工作表 Sheet1 的左页边距设为 5 厘米“Worksheets(“Sheet1“).PageSetup.LeftMargin = Application.CentimetersToPoints(5)End Sub示例 01-16:使用 Windows 的计算器(ActivateMicrosoftApp 方法)Sub CallC
28、alculate()Application.ActivateMicrosoftApp Index:=0End Sub示例说明:运行本程序后,将调用 Windows 的计算器。示例 01-17:在程序中运行另一个宏 (Run 方法)Sub runOtherMacro()MsgBox “本程序先选择 A1 至 C6 单元格区域后执行 DrawLine 宏“ActiveSheet.Range(“A2:C6“).SelectApplication.Run “DrawLine“End Sub示例 01-18:在指定的时间执行宏 (OnTime 方法)Sub AfterTimetoRun()MsgBox
29、“从现在开始,10 秒后执行程序testFullScreen“Application.OnTime Now + TimeValue(“00:00:10“), “testFullScreen“End Sub示例说明:运行本程序后,在 10 秒后将执行程序 testFullScreen。示例 01-19:暂时停止宏运行 (Wait 方法)Sub Stop5sMacroRun()Dim SetTime As DateMsgBox “按下确定,5 秒后执行程序testFullScreen“14SetTime = DateAdd(“s“, 5, Now()Application.Wait SetTime
30、Call testFullScreenEnd Sub示例说明:运行本程序后,按下弹出的提示框中的“确定”按钮,等待 5 秒后执行另一程序 testFullScreen。示例 01-20:按下指定的按键后执行程序 (OnKey 方法)示例 01-20-1Sub PressKeytoRun()MsgBox “按下 Ctrl+D 后将执行程序testFullScreen“Application.OnKey “d“, “testFullScreen“End Sub示例 01-20-2Sub ResetKey()MsgBox “恢复原来的按键状态“Application.OnKey “d“End Sub
31、示例说明:Onkey 方法的作用主要是指定特定的键,当按下指定的键时运行相应的宏程序,或者按下指定的键时,使 Excel 屏蔽特定的功能。示例 01-21:重新计算工作簿示例 01-21-1Sub CalculateAllWorkbook()Application.CalculateEnd Sub示例说明:当工作簿的计算模式被设置为手动模式后,运用 Calculate 方法可以重新计算所有打开的工作簿、工作簿中特定的工作表或者工作表中指定的单元格区域。示例 01-21-2Sub CalculateFullSample()If Application.CalculationVersion Exc
32、elVBA 编程入门范例Window 对象代表一个窗口,约有 48 个属性和 14 个方法,能对窗口特性进行设置和操作。Window 对象是 Windows 集合中的成员,对于 Application 对象来说,Windows 集合包含该应用程序中的所有窗口;对于 Workbook 对象来说,Windows 集合只包含指定工作簿中的窗口。下面介绍一些示例,以演示和说明 Window 对象及其属性和方法的运用。示例 02-01:激活窗口(Activate 方法)Sub SelectWindow()17Dim iWin As Long, i As Long, bWinMsgBox “依次切换已打开
33、的窗口“iWin = Windows.CountMsgBox “您已打开的窗口数量为: ” & iWinFor i = 1 To iWinWindows(i).ActivatebWin = MsgBox(“您激活了第 “ & i & “个窗口,还要继续吗?“, vbYesNo)If bWin = vbNo Then Exit SubNext iEnd Sub示例 02-02:窗口状态(WindowState 属性)示例 02-02-01Sub WindowStateTest()MsgBox “当前活动工作簿窗口将最小化“Windows(1).WindowState = xlMinimizedM
34、sgBox “当前活动工作簿窗口将恢复正常“Windows(1).WindowState = xlNormalMsgBox “当前活动工作簿窗口将最大化“Windows(1).WindowState = xlMaximizedEnd Sub示例说明:使用 WindowState 属性可以返回或者设置窗口的状态。示例中,常量 xlMinimized、xlNormal 和 xlMaximized 分别代表窗口不同状态值,Windows(1)表示当前活动窗口。可以使用 Windows(index)来返回单个的 Window 对象,其中的 index 为窗口的名称或编号,活动窗口总是 Windows(
35、1)。示例 02-02-02Sub testWindow()测试 Excel 应用程序窗口状态MsgBox “应用程序窗口将最大化“Application.WindowState = xlMaximizedCall testWindowStateMsgBox “应用程序窗口将恢复正常“Application.WindowState = xlNormalMsgBox “应用程序窗口已恢复正常“测试活动工作簿窗口状态MsgBox “当前活动工作簿窗口将最小化“ActiveWindow.WindowState = xlMinimizedCall testWindowStateMsgBox “当前活动
36、工作簿窗口将最大化“ActiveWindow.WindowState = xlMaximizedCall testWindowStateMsgBox “当前活动工作簿窗口将恢复正常“ActiveWindow.WindowState = xlNormalCall testWindowState18MsgBox “应用程序窗口将最小化“Application.WindowState = xlMinimizedCall testWindowStateEnd Sub*Sub testWindowState()Select Case Application.WindowStateCase xlMaxim
37、ized: MsgBox “应用程序窗口已最大化“Case xlMinimized: MsgBox “应用程序窗口已最小化“Case xlNormal:Select Case ActiveWindow.WindowStateCase xlMaximized: MsgBox “当前活动工作簿窗口已最大化“Case xlMinimized: MsgBox “当前活动工作簿窗口已最小化“Case xlNormal: MsgBox “当前活动工作簿窗口已恢复正常 “End SelectEnd SelectEnd Sub示例说明:本示例有两个程序,其中 testWindow()是主程序,调用子程序 te
38、xtWindowState(),演示了应用程序窗口和工作簿窗口的不同状态。当前活动窗口一般代表当前活动工作簿窗口,读者可以在 VBE 编辑器中按 F8 键逐语句运行testWindow()程序,观察 Excel 应用程序及工作簿窗口的不同状态。此外,在子程序中,还运用了嵌套的 Select Case 结构。示例 02-02-03Sub SheetGradualGrow()Dim x As IntegerWith ActiveWindow.WindowState = xlNormal.Top = 1.Left = 1.Height = 50.Width = 50For x = 50 To App
39、lication.UsableHeight.Height = xNext xFor x = 50 To Application.UsableWidth.Width = xNext x.WindowState = xlMaximizedEnd WithEnd Sub示例说明:本示例将动态演示工作簿窗口由小到大直至最大化的变化过程。在运行程序时,您可以将 VBE 窗口缩小,从而在工作簿中查看动态效果,也可以在 Excel 中选择菜单中的宏命令执行以查看效果。19示例 02-03:切换显示工作表元素示例 02-03-01Sub testDisplayHeading()MsgBox “切换显示/隐藏行
40、列标号”ActiveWindow.DisplayHeadings = Not ActiveWindow.DisplayHeadingsEnd Sub示例说明:本示例切换是否显示工作表中的行列标号。运行后,工作表中的行标号和列标号将消失;再次运行后,行列标号重新出现,如此反复。您也可以将该属性设置为 False,以取消行列标号的显示,如 ActiveWindow.DisplayHeadings = False;而将该属性设置为 True,则显示行列标号。示例 02-03-02Sub testDisplayGridline()MsgBox “切换显示/隐藏网格线”ActiveWindow.Disp
41、layGridlines = Not ActiveWindow.DisplayGridlinesEnd Sub示例说明:本示例切换是否显示工作表中的网格线。运行后,工作表中的网格线消失,再次运行后,网格线重新出现,如此反复。您也可以将该属性设置为False,以取消网格线显示,如 ActiveWindow.DisplayGridlines = False;而将该属性设置为 True,则显示网格线。示例 02-03-03Sub DisplayHorizontalScrollBar()MsgBox “切换显示/隐藏水平滚动条”ActiveWindow.DisplayHorizontalScrollB
42、ar = _Not ActiveWindow.DisplayHorizontalScrollBarEnd Sub示例说明:本示例切换是否显示工作表中的水平滚动条。运行后,工作表中的水平滚动条消失,再次运行后,水平滚动条重新出现,如此反复。您也可以将该属性设置为 False,以取消水平滚动条,如 ActiveWindow.DisplayHorizontalScrollBar = False;而将该属性设置为 True,则显示水平滚动条。同理,DisplayVerticalScrollBar 属性将用来设置垂直滚动条。示例 02-03-04Sub DisplayScrollBar()MsgBox
43、“切换显示/隐藏水平和垂直滚动条“Application.DisplayScrollBars = Not (Application.DisplayScrollBars)End Sub示例说明:本示例切换是否显示工作表中的水平和垂直滚动条。运行后,工作表中的水平和垂直滚动条同时消失,再次运行后,水平和垂直滚动条重新出现,如此反复。您也可以将该属性设置为 False,以取消水平和垂直滚动条显示,如 Application.DisplayScrollBars= False;而将该属性设置为 True,则显示水平和垂直滚动条。示例 02-04:显示公式(DisplayFormulas 属性)Sub D
44、isplayFormula()MsgBox “显示工作表中包含公式的单元格中的公式”20ActiveWindow.DisplayFormulas = TrueEnd Sub示例说明:本程序运行后,工作表中含有公式的单元格将显示公式而不是数值。若要显示数值,则将该属性设置为 False,或者,如果工作表中的公式显示的是结果数值,则该属性为 False。示例 02-05:显示/隐藏工作表标签(DisplayWorkbookTabs 属性)Sub testDisplayWorkbookTab()MsgBox “隐藏工作表标签 ”ActiveWindow.DisplayWorkbookTabs = F
45、alseEnd Sub示例说明:本程序运行后,工作表标签消失。将该属性设置为 True,重新显示工作表标签。示例 02-06:命名活动窗口 (Caption 属性)Sub testCaption()MsgBox “当前活动工作簿窗口的名字是:“ & ActiveWindow.CaptionActiveWorkbook.Windows(1).Caption = “我的工作簿“MsgBox “当前活动工作簿窗口的名字是:“ & ActiveWindow.CaptionEnd Sub示例说明:本程序运行后,显示当前活动工作簿窗口原先的名称(即工作簿窗口未处于最大化状态时,出现在窗口顶部标题栏中的文字
46、),然后设置当前活动工作簿窗口名称,即使用语句 ActiveWorkbook.Windows(1).Caption = “我的工作簿“,最后显示当前活动工作簿窗口的新名称。改变窗口的标题并不会改变工作簿的名称。示例 02-07:移动窗口到指定位置 (ScrollRow 属性和 ScrollColumn 属性)Sub testScroll()MsgBox “将当前窗口工作表左上角单元格移至第 10 行第 3 列”ActiveWindow.ScrollRow = 10ActiveWindow.ScrollColumn = 3End Sub示例说明:本程序运行后,当前活动窗口左上角单元格为第 10
47、行第 3 列。可以通过设置这两个属性来移动窗口到指定的位置,也可以返回指定窗格或窗口最左上面的行号或列号。示例 02-08:调整窗口(EnableResize 属性)Sub testResize()MsgBox “设置窗口大小不可调整 ”ActiveWindow.EnableResize = FalseEnd Sub示例说明:测试本程序前,将当前工作簿窗口恢复为正常状态(即让工作簿标题可见),运行程序后,当前工作簿窗口将不能调整其大小,右上角的最小化最大化按钮将消失(即隐藏最大化和最小化按钮)。该属性设置为 True,则能调整窗21口大小。示例 02-09:拆分窗格示例 02-09-01Sub
48、 SplitWindow1()Dim iRow As Long, iColumn As LongMsgBox “以活动单元格为基准拆分窗格“iRow = ActiveCell.RowiColumn = ActiveCell.ColumnWith ActiveWindow.SplitColumn = iColumn.SplitRow = iRowEnd WithMsgBox “恢复原来的窗口状态“ActiveWindow.Split = FalseEnd Sub示例 02-09-02Sub SplitWindow()Dim iRow As Long, iColumn As LongMsgBox
49、“以活动单元格为基准拆分窗格“iRow = ActiveCell.RowiColumn = ActiveCell.ColumnWith ActiveWindow.SplitColumn = iColumn.SplitRow = iRowEnd WithMsgBox “恢复原来的窗口状态“ActiveWindow.SplitColumn = 0ActiveWindow.SplitRow = 0End Sub示例说明:本示例演示了以活动单元格为基准拆分窗格。如果指定窗口被拆分,则 Split 属性的值为 True;设置该属性的值为 False 则取消窗格拆分。也可以设置 SplitColumn 属性和 SplitRow 属性的值来取消窗格拆分。示例 02-10:冻结窗格(FreezePan