ExcelVBA编程实例(150例).docx
EXCeiVBA编程实例(150例)主要内容和特点ExcelVBA编程入门范例主要是以一些基础而简短的VBA实例来对ExceIV BA中的常用对象及其属性和方法进行讲解,包括应用程序对象、窗口、工作簿、 工作表、单元格和单元格区域、图表、数据透视表、形状、控件、菜单和工具栏、 帮助助手、格式化操作、文件操作、以及常用方法和函数及技巧等方面的应用示 例。这些例子都比较基础,很容易理解,因而,很容易调试并得以实现,让您通 过具体的实例来熟悉ExceIVBA编程。 分16章共14个专题,以具体实例来对大多数常用的EXCeIVBA对象进行讲 解; 一般而言,每个实例都很简短,用来说明使用VBA实现EXCel某一功能的操 作; 各章内容主要是实例,即VBA代码,配以简短的说明,有些例子可能配以必 要的图片,以便于理解; 您可以对这些实例进行扩充或组合,以实现您想要的功能或更复杂的操作。VBE编辑器及VBA代码输入和调试的基本知识在学习这些实例的过程中,最好自己动手将它们输入到VBE编辑器中调试运行, 来查看它们的结果。当然,您可以偷赖,将它们复制/粘贴到代码编辑窗口后, 进行调试运行。下面,对VBE编辑器界面进行介绍,并对VBA代码输入和调试 的基本知识进行简单的讲解。激活VBE编辑器一般可以使用以下三种方式来打开VBE编辑器: 使用工作表菜单“工具宏Visual BaSiC编辑器”命令,如图OO-Ol所示; Visual BaSiC工具栏上,按“Visual BaSiC编辑器”按钮,如图Oo-O2所示; 按Alt+F11组合键。了具数据也)窗口 置)整助国)拼写检查). 信息检索®. . 错误检查隹). 语音国)FTAlt+Click蟆 ?宋体K I键入彳 12,共享工作区也).共享工作溥(!).修订复)比较和合并工作簿®).保护U)联机协作国)单变量求解6).方案熠).公式审核)I宏®)宏 也).Alt÷F8加载宏9自动更正选项(A).录制新宏 安全性6).一自定义©乃Visual Basic 编辑器 W)Alt+Fll选项(Q).SMicrosoft脚本编辑器置Alt+Shift+Fll图OO-01 :选择菜单“工具宏一Visual Basic编辑器”命令来打开VBE编辑Vi sual Basi c/。安全. 乃戈吆8Visual BaSiC 编辑器|图OO-O2:选择ViSUal BaSiC工具栏上的“Visual BaSiC编辑器”命令按钮来打开 VBE编辑器此外,您也可以使用下面三种方式打开VBE编辑器: 在任一工作表标签上单击鼠标右键,在弹出的菜单中选择“查看代码”,则可 进入VBE编辑器访问该工作表的代码模块,如图OO-O3所示; 在工作簿窗口左上角的EXCel图标上单击鼠标右键,在弹出的菜单中选择 “查看代码”,贝尸进入VBE编辑器访问活动工作簿的ThisWorkbook代码模块, 如图Oo-O4所示; 选择菜单“工具宏宏”命令打开宏对话框,若该工作簿中有宏程序, 则单击该对话框中的“编辑”按钮即可进行VBE编辑器代码模块,如图00-05所 示。插入(X).删除)重命名电)移动或复制工作表(M)选定全部工作表)工作表标签颜色O.反查看代码国) M She图OO-O3:右击工作表标签弹出菜单并选择“查看代码”打开VBE编辑器当文件国)编辑世I,保存)另存为(A)"3打印9一页面设置(U).c拼写检查).新建窗口 (N)重排窗口 &).显示比例).旧查看代码4)图Oo-O4:右击Excel图标弹出菜单并选择“查看代码”打开VBE编辑器图00-05:在宏对话框中单击“编辑”按钮打开VBE编辑器VBE编辑器窗口简介刚打开VBE编辑器时,所显示的窗口如图00-06所示,其中没有代码模块窗口。伍 Microsoft Visual Basic - Bookl文件®编辑® 艇5插入1)格式Q)调试运行工具外接程序因窗口)帮助凶 国土H,U上超摩二.QemmEtt - SheetlSheetl Worksheet 按字聃I技分类序I(名称)DisplayFageBreaks FalseDisDlavRiehtToLeft False图OO-O6:刚打开VBE编辑器时的窗口可以在“工程资源管理器”中双击任一对象打开代码窗口,或者选择菜单“插入一 模块”或“插入类模块”来打开代码窗口。一般VBE编辑器窗口及各组成部件 名称如图OO-O7所示,可以通过“视图”菜单中的菜单项选择所出现的窗口。同时, 可以在“工程属性”窗口中设置或修改相应对象的属性。标题栏对象卜力菜单栏J一片 文件。 编辑 视图9 插入9 格式仍 调试 运行® 工具)外接陶具栏USJ3-0 通第o>mM T & Qjj Microsoft Visual Basic - BOOkI-模块 1 (代吗)程-VBAProjectH)I - B 对象 VBlProject (Bookl)S 1J Microsoft Excel 对象 r¢) Sheetl (Sheetl)“I前作簿对象'Fsheet2 2)代码模块类模块.B S模块一一您模块1白巴类模块类Sheet3 (Sheet3) Thi sWorkbookI:程资源管理器窗口Option Explicit代码模块窗性模块1篌块1模块按字母序I按分类序I(名称)模块11:程属性窗口21I立即窗口立即窗口图OO-O7: VBE编辑器窗口下面是带有用户窗体的VBE编辑器窗口,如图00-08所示。选择VBE菜单“插 入用户窗体”,即可插入一个用户窗体。当插入用户窗体后,在“工程资源管理器”窗口中会出现一个用户窗体对象,“工程属性”窗口显示当前用户窗体的属性, 可对相关属性进行设置或修改。同时,在用户窗体上用鼠标单击,会出现“控件 工具箱”。在“工程资源管理器”窗口双击用户窗体图标,会出现相应的用户窗体; 在用户窗体图标或者是在用户窗体上单击鼠标右键,然后在弹出的菜单中选择 “查看代码”,则会出现用户窗体代码窗口。图OO-O8: VBE编辑器窗口(带有用户窗体)在VBE编辑器中输入VBA代码 如前所述,您可以选择VBE菜单“插入用户窗体/模块/类模块”来插入模块或 用户窗体以及相应的代码窗口。此外,您也可以在“工程资源管理器”中单击鼠标 右键,从弹出的菜单中选择“插入用户窗体/模块/类模块”来实现上面的操作。 在获取相应的代码模块窗口后,就可以输入VBA代码了。在VBE编辑器的代码模块中输入VBA代码,通常有以下几种方法: 手工键盘输入; 使用宏录制器,即选择菜单“工具宏录制新宏”命令,将所进行的操作 自动录制成宏代码; 复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中; 导入代码模块,即在VBE编辑器中选择菜单“文件导入文件”或在“工程资 源管理器”的任一对象上右击鼠标选择菜单“导入文件”,选择相应的代码文件导入。 如果不想要某个模块了,可以选择菜单“文件移除模块”,也可以在相应的模 块上单击鼠标右键,从弹出的菜单中选择“移除模块”。此时,会弹出一个警告框, 询问在移除模块前是否将其导出,可以根据需要进行选择。也可以选择菜单“文件导出文件”或在相应的模块上单击鼠标右键后,从弹出 的菜单中选择“导出文件”,将移除的模块保存在相应的文件夹中。这样,以后可 以对其进行导入,从而加以利用。调试VBA代码在VBE编辑器的菜单中,有两项与调试运行有关的菜单项,即“调试”菜单和“运 行”菜单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常 用到的有以下几个: 逐语句。可以按F8键对代码按顺序一条一条语句运行,从而找出语句或逻辑 错误。 设置断点。在可能存在问题的语句处设置断点(可通过在相应代码前的空白部 位单击,将会出现一个深红色的椭圆即断点),当程序运行至断点处时,会中止 运行。 在语句的适当部位设置DebUg.Print语句,运行后其结果会显示在“立即窗口” 中,可以此测试或跟踪变量的值。 在“立即窗口”中测试。对值的测试或跟踪,也可以以“? ”开头,在“立即窗口” 中输入需要测试值的语句,按Enter回车键后将立即出现结果;对执行语句的测 试,可直接在“立即窗口”中输入,按Emer回车键后将执行。 可以按F5键直接运行光标所在位置的子程序。在执行程序后,必须在EXCel工作表中查看所得到的结果。可以用鼠标单击VB E编辑器左上角的Excel图标或者是按Alt+F11组合键切换到Excel界面。(当然,对程序代码的调试有很多方法和技巧,留待以后对VBA进一步研究和理 解更透彻后一并讨论。)利用VBA帮助系统如果遇到疑问或错误,可以利用Excel自带的VBA帮助系统。 可以在如图OO-O9所示的部位输入需要帮助的关键词,按Enter回车键后将会 出现相关主题。用鼠标单击相应的主题即会出现详细的帮助信息。健入需要帮助的问题图Oo-O9:帮助搜索窗口 可以按F2键,调出“对象浏览器”窗口(如图OO-IO所示),在搜索文本框中输 入需要帮助的关键词,将会在“搜索结果”中出现一系列相关的对象及方法、属性列表,单击相应的对象则会在“类”和“成员”列表框中显示相应的对象和方法、属 性成员列表,在成员列表中相应的项目上按F1键即会出现详细的帮助信息。(“对 象浏览器”是一个很好的帮助工具,值得好好研究)图OO-10:对象浏览器窗口参考资料ExcelVBA编程入门范例参考或引用了以下书籍和资料:(I)ExceI 2003高级VBA编程宝典(2)Excel 2003与VBA编程从入门到精通(中文版) (3)巧学巧用Excel 2003 VBA与宏(中文版) (4)ExcelVBA应用程序专业设计实用指南 (5)ExcelVBA应用开发与实例精讲(6)一些网上资源更多的信息关于EXCelVBA的更多参考和学习资源,可以在WWW 1二查找, 有疑问也可以在ExceIHome论坛中提问。您也可以登录我的博客http:faniv.bl OQ,上面有很多EXCel的学习资料。同时,欢迎与我联系交流, 我的 e-mail 是:XhdSXfiV n“学习Excel,使用VBA对Excel进行控制操作是我很热衷的业余爱好之一。”fanjy第一章Excel应用程序对象(APPIiCatiOn对象)及其常用方法基本操作应用示例:Exce!VBA»ExcelVBA 编程入门范例Application对象代表整个Microsoft Excel应用程序,带有175个属性和52个 方法,可以设置整个应用程序的环境或配置应用程序。示例01-01:体验开/关屏幕更新(SCreenUPdating属性)Sub关闭屏幕更新()MsgBox ”顺序切换工作表Sheet1 Sheet2Sheet3Sheet2,先开启屏幕 更新,然后关闭屏幕更新“Worksheets(1).SelectMsgBox "目前屏幕中显示工作表Sheet1”AppIication.ScreenUpdating = TrueWorksheets(2).SelectMsgBox ”显示 Sheet2 了 吗?”Worksheets(S),SeIectMsgBox "显示 Sheet3 了吗?”Worksheets(2).SelectMsgBox ”下面与前面执行的程序代码相同,但关闭屏幕更新功能”Worksheets(1).SelectMsgBox ”目前屏幕中显示工作表Sheet1" & Chr(W) & ”关屏屏幕更新功能”AppIication.ScreenUpdating = FalseWorksheets(2).SelectMsgBox ”显示 Sheet2 了 吗?”Worksheets(S),SeIectMsgBox ”显示 Sheet3 了吗?”Worksheets(2).SelectAppIication.ScreenUpdating = TrueEnd Sub示例说明:ScreenUpdating属性用来控制屏幕更新。当运行一个宏程序处理涉 及到多个工作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CP U的处理时间,从而降低程序的运行速度,而关闭该属性则可显著提高程序运行 速度。示例0102:使用状态栏(StatUSBar属性)Sub testStatusBar()Application.DispIayStatusBar = True '开启状态栏显示'赋值状态栏显示的文本AppIication.StatusBar = "http: ”End Sub示例说明:StatUSBar属性用来指定显示在状态栏上的信息。若不想再显示状态 栏文本,可使用APPliCation.StatusBar = FaISe语句关闭状态栏显示,也可以在 程序开始将原先的状态栏设置存储,如使用语句OldStatUSBar = Application.Di SpIayStatusBar将状态栏原来的信息存储在变量OIdStatUSBar,在程序运行完成 或退出时,将变量重新赋值给状态栏,如使用语句APPliCation.DispIayStatusBa r = OldStatusBar,以恢复状态栏原状。示例0103:处理光标(CUrSOr属性)Sub ViewCursorsOApplication.Cursor = XlNorthwestArrowMsgBox ”您将使用箭头光标,切换到Excel界面查看光标形状”Application.Cursor = XlIBeamMsgBox ”您将使用工形光标,切换到EXCel界面查看光标形状”Application.Cursor = XlWaitMsgBox ”您将使用等待形光标,切换到EXCeI界面查看光标形状”Application.Cursor = XlDefauItMsgBox ”您已将光标恢复为缺省状态”End Sub示例0104:获取系统信息Sub GetSystemInfoOMsgBox "Excel 版东信息为:” & Application.CalcuIationVersionMsgBox "Excel 当前允许使用的内力为:"& AppIication.MemoryFreeMsgBox "Excel 当前已使用的内存为:" & AppIication.MemoryUsedMsgBox "Excel 可以使用的内存为:" & AppIication.MemoryTotaIMsgBox "本机操作系统的名称和版本为:"& AppIication-OperatingSystem MsgBox ”本产品所登记的组织名为:" & AppIication.OrganizationNameMsgBox ”当前用户名为:“ & AppIication.UserNameMsgBox ”当前使用的 EXCel 版未为:" & Application.VersionEnd Sub示例说明:可以使用给UserName属性赋值以设置用户名称。示例01-05:退出复制/剪切模式(CUtCOPyMOde属性)Sub exitCutCopyMode()Application.CutCopyMode = FalseEnd Sub示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会 在原单元格区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用A Pplication.CutCopyMode = False语句恢复该属性的默认设置。示例01-06:禁止弹出警告信息(DiSPIayAIertS属性)Sub IestAIertsDispIayOApplication.DispIayAIerts = FalseEnd Sub示例说明:在程序运行过程中,有时由于EXCel本身设置的原因,会弹出对话框, 从而中断程序的运行,您可以在程序之前加上Application.DispIayAIerts = Fal Se语句以禁止弹出这些对话框而不影响程序正常运行。需要注意的是,在程序 运行结束前,应使DiSPIayAlertS属性恢复为缺省状态,即使用语句APPliCation. DispIayAIerts = TrUe。该属性的默认设置为TrUe,当将该属性设置为FaISe时, Excel会使直接使用对话框中默认的选择,从而不会因为弹出对话框而影响程序 运行。示例0107:将EXCel全屏幕显示Sub testFullScreen()MsgBox ”运行后将Excel的显示模式设置为全屏幕”Application.DispIayFuIIScreen = TrueMsgBox ”恢复为原来的状态”Application.DispIayFuIIScreen = FalseEnd Sub示例Ol-O8: EXCel启动的文件夹路径Sub ExceIStartfoIderOMsgBox "Excel 启动的文件夹路径为:"& Chr(10) & AppIication-StartupPa thEnd Sub示例0109:打开最近使用过的文档Sub OpenRecentFiIesOMsgBox ”显示最近使用过的第三个文件名,并打开该文件”MsgBox ”最近使用的第三个文件的名称为:" & AppIication.RecentFiIes(S).N ameApplication.RecentFiIes(S)-OpenEnd Sub示例01-10:打开文件(FindFile方法)Sub FindFiIeOpenOOn Error Resume NextMsgBox "请打开文件",VbOKOnIy + VblnformatiOn,"打开文件”If Not AppIication.FindFiIe ThenMsgBox "文件未找到",VbOKOnIy + VbInfOnnatiOn,"打开失败"End IfEnd Sub示例说明:本示例将显示“打开”文件对话框,若用户未打开文件(即点击“取消”按 钮),则会显示“打开失败”信息框。示例中使用了 FindFiIe方法,用来显示“打开” 对话框并让用户打开一个文件。如果成功打开一个新文件,则该值为Trueo如 果用户取消了操作并退出该对话框,则该值为False。示例0111:文件对话框操作(FiIeDialOg属性)Sub UseFiIeDiaIogOpenODim IngCount As Long'开启”打开文件”对话框With Application.FileDialog(msoFileDialogOpen).AllowMuItiSeIect = True.Show'显示所选的每个文件的路径For IngCount = 1 To .Selectedltems.CountMsgBox .SelectedItems(IngCount)Next IngCountEnd WithEnd Sub示例说明:本示例显示“打开文件”对话框,当用户在其中选择一个或多个文件后, 将依次显示每个文件的路径。其中,FiieDialog属性返回打开和保存对话框中一 系列对象的集合,您可以对该集合对象的属性进行进一步的设置,如上例中的A IlowMuItiSeIect属性设置为True将允许用户选择多个文件。示例保存EXCel的工作环境Sub保存Excel的工作环境()MsgBox ”将Excel的工作环境保存到DAExceISampIe'中”Application.SaveWorkspace "D:ExcelSampleSample"End Sub示例说明:运行本程序后,将工作簿以带后缀名/IW保存到D盘的EXCeISamPl e文件夹中,生成的文件全名为Sample.Xlwo当改变工作簿并保存时,Excel 会询问是覆盖原文件还是保存副本。示例(TM3:改变EXCel工作簿名字(CaPtiOn属性)Sub SetCaptionOApplication.Caption = My ExceIBook"End Sub示例说明:运行本程序后,将工作簿左上角EXCel图标右侧的“Microsoft Exceln改为“My ExcelBook:示例01-14:使用InPUtBoX方法Sub SampleInputBoxODim vlnputvlnput = InPUtBOx(”请输入用户名'获取用户名* AppIication.UserName)MsgBox "您好!” & Vlnput & ”.很高兴能认识您VbOKOnM "打招呼”End Sub示例01-15:设置页边距(CentimeterSTOPOintS方法)Sub SetLeftMarginOMsgBox ”将工作表Sheetl的左页边距设为5厘米”Worksheets(nSheetIn),PageSetup.LeftMargin = AppIication.CentimetersToPoints(5)End Sub示例 01-16:使用 Windows 的计算器(ACtiVateMiCrOSOftAPP 方法)Sub CallCaIcuIateOApplication.ActivateMicrosoftApp Indexr=OEnd Sub示例说明:运行本程序后,将调用WindOWS的计算器。示例在程序中运行另一个宏(RUn方法)Sub ruOtherMacro()MsgBox ”本程序先选择A1至C6单元格区域后执行DrawLine宏”ActiveSheet.Range(HA2:C6").SelectApplication.Run nDrawLine"End Sub示例01-18:在指定的时间执行宏(OnTime方法)Sub AfterTimetoRunOMsgBox ”从现在开始,10秒后执行程序FtestFuIIScreenJ ”AppIication.OnTime Now + TimeValue(H00:00:10"), "testFullScreen" End Sub示例说明:运行本程序后,在10秒后将执行程序testFullScreen。示例01-19:暂时停止宏运行(Wait方法)Sub Stop5sMacroRun()Dim SetTime As DateMsgBox ”按下!确定,5秒后执行程序FtestFuIIScreenJ ,SetTime = DateAdd("s, 5, Now()Application.Wait SetTimeCall testFullScreenEnd Sub示例说明:运行本程序后,按下弹出的提示框中的“确定”按钮,等待5秒后执行另一程序 testFullScreen o示例0120:按下指定的按键后执行程序(OnKey方法)示例 01-20-1Sub PressKeytoRunOMsgBox ”按下 Ctrl+D 后将执行程序 FtestFuIIScreenJ "AppIication.OnKey "cI"j ''testFullScreen'1End Sub示例 01-20-2Sub ResetKeyOMsgBox ”恢复原来的按键状态”AppIication.OnKey "cI"End Sub示例说明:Onkey方法的作用主要是指定特定的键,当按下指定的键时运行相 应的宏程序,或者按下指定的键时,使EXCel屏蔽特定的功能。示例重新计算工作簿示例 01-21-1Sub CalculateAlIWorkbookOApplication.CalculateEnd Sub示例说明:当工作簿的计算模式被设置为手动模式后,运用CalCUIate方法可以 重新计算所有打开的工作簿、工作簿中特定的工作表或者工作表中指定的单元格 区域。示例 01-21-2Sub CalculateFuIISampIeOIf Application.CalcuIationVersion <> Workbooks(1).Calculation Version The nApplication.CalcuIateFuIIEnd IfEnd Sub示例说明:本示例先将当前Microsoft Excel的版本与上次计算该工作簿的Exc el版本进行比较,如果两个版本不同,则对所有打开工作簿中的数据进行一次完 整计算。其中,CaIeUlatiOnVerSiOn属性返回工作簿的版本信息。示例0122:控制函数重新计算(VOlatiIe方法)Function NonStaticRandO'当工作表中任意单元格重新计算时本函数更新Application.Volatile TrueNonStaticRand = Rnd()End Function示例说明:本示例摸仿Excel中的Rand()函数,当工作表单元格发生变化时, 都会重新计算该函数。在例子中,使用了 Volatile方法,强制函数进行重新计算, 即无论何时重新计算工作表,该函数都会重新计算。示例01-23:利用工作表函数(WOrkSheetFUnCtiOn属性)Sub WorksheetFunctionSampIeODim myRange As Range, answerSet myRange = Worksheets(,Sheet1 ").Range("A1 :C10") answer = Application. WorksheetFunction.Min(myRange) MsgBox answerEnd Sub示例说明:本示例获取工作表SheetI中单元格区域A1:CIo中的最小值,使用 了工作表函数Min()。一般,使用WorkSheetFUnCtion属性引用工作表函数,但 如果VBA自带有实现相同功能的函数,则直接使用该函数,否则会出现错误。示例0124:获取重叠区域(InterSeCt方法)Sub IntersectRangeODim rSect As RangeWorksheets(,'Sheet1,'). ActivateSet rSect = Application.lntersect(Range(',rg1u), Range("rg2)If rSect Is Nothing ThenMsgBox ”没有交叉区域”ElserSect. SelectEnd IfEnd Sub示例说明:本示例在工作表SheetI中选定两个命名区域rg1和rg2的重叠区域, 如果所选区域不重叠,则显示一条相应的信息。其中,Intersect方法返回一个R ange对象,代表两个或多个范围重叠的矩形区域。示例01-25:获取路径分隔符(PathSeParatOr属性)Sub GetPathSeparatorOMsgBox "路径分隔符为"& AppIication.PathSeparatorEnd Sub示例说明:本示例使用PathSeParator属性返回路径分隔符CV)。示例01-26:快速移至指定位置(GOtO方法)Sub GotoSampIeOApplication.Goto Reference:=Worksheets("Sheet1 u).Range("A154"), _ ScroIk=TrueEnd Sub示例说明:本示例运行后,将当前单元格移至工作表Sheetl中的单元格AI54。示例0127:显示内置对话框(DiaIOgS属性)Sub DiaIogSampIeOApplication.Dialogs(XlDiaIogOpen),ShowEnd Sub示例说明:本示例显示EXCel的“打开”文件对话框。其中,DiaIogS属性返回的 集合代表所有的EXCel内置对话框。示例 01-28:退出 Excel(SendKeys 方法)Sub SendKeysSampIeOAppIication.SendKeys ("%fx")End Sub示例说明:本示例使用SendKeyS方法退出Excel,若未保存,则会弹出提示对 话框并让用户作出相应的选择。SendKeyS方法的作用是摸拟键盘输入,如例中 的“fx”表示在Excel中同时按下Alt、F和X三个键。示例0129:关闭EXCelSub 关闭 Excel()MsgBox "Excel 将会关闭"Application.QuitEnd Sub示例说明:运行本程序后,若该工作簿未保存,则会弹出对话框询问是否保存。(by fanjy)第二章窗口(Window对象)基本操作应用示例(一)分类:食磔!辿>>ExcelVBA编程入门范例WindOW对象代表一个窗口,约有48个属性和14个方法,能对窗口特性进行设 置和操作。WindOW对象是Windows集合中的成员,对于Application对象来说, WindOWS集合包含该应用程序中的所有窗口;对于WOrkboOk对象来说,Wind OWS集合只包含指定工作簿中的窗口。下面介绍一些示例,以演示和说明Wind ow对象及其属性和方法的运用。示例0201 :激活窗口(Activate方法)Sub SeIectWindowODim iWin As Long, i As Long, bWinMsgBox ”依次切换已打开的窗口”iWin = Windows.CountMsgBox “您已打开的窗口数量为:" & iWinFor i = 1 To iWinWindows(S),ActivatebWin = MSgBox(“您激活了第"& i & ”个窗口,还要继续吗? ",VbYesNo)If bWin = vbNo Then Exit SubNext iEnd Sub示例02-02:窗口状态(WindOWState属性)示例 02-02-01Sub WindowStateTestOMsgBox ”当前活动工作簿窗口将最小化”Windows(1).WindowState = XlMinimizedMsgBox ”当前活动工作簿窗口将恢复正常”Windows(1).WindowState = XlNormaIMsgBox ”当前活动工作簿窗口将最大化”Windows(1).WindowState = XlMaximizedEnd Sub示例说明:使用WindOWState属性可以返回或者设置窗口的状态。示例中,常 量 XIMinimiZed、XlNorrnal 和 XlMaXimiZed 分别代表窗口不同状态值,Windows 表示当前活动窗口。可以使用WindoWS(index)来返回单个的Window对象, 其中的index为窗口的名称或编号,活动窗口总是Windows(I)o示例 02-02-02Sub testWindow()恻试Excel应用程序窗口状态MsgBox ”应用程序窗口将最大化”AppIication.WindowState = XlMaximizedCall IestWindowStateMsgBox ”应用程序窗口将恢复正常“AppIication.WindowState = XlNormaIMsgBox ”应用程序窗口已恢复正常”测试活动工作簿窗口状态MsgBox ”当前活动工作簿窗口将最小化”ActiveWindow. WindowState = XlMinimizedCall testWindowStateMsgBox ”当前活动工作簿窗口将最大化”ActiveWindow. WindowState = XlMaximizedCall testWindowStateMsgBox ”当前活动工作簿窗口将恢复正常“ActiveWindow.WindowState = XlNormaICall IestWindowStateMsgBox ”应用程序窗口将最小化”AppIication.WindowState = XlMinimizedCall IestWindowStateEnd SubSub testWindowState()Select Case AppIication.WindowStateCase XlMaximized: MsgBox ”应用程序窗口已最大化”Case XlMinimized: MsgBox ”应用程序窗口已最小化”Case XlNormaI:Select Case ActiveWindow.WindowStateCase XlMaximized: MsgBox ”当前活动工作簿窗口已最大化”Case XlMinimized: MsgBox ”当前活动工作簿窗口已最小化"Case XlNormaI: MsgBox "当前活动工作簿窗口已恢复正常"End SelectEnd SelectEnd Sub示例说明:本示例有两个程序,其中testWindow()是主程序,调用子程序text WindowStateO,演示了应用程序窗口和工作簿窗口的不同状态。当前活动窗口 一般代表当前活动工作簿窗口,读者可以在VBE编辑器中按F8键逐语句运行t estWindow()程序,观察EXCel应用程序及工作簿窗口的不同状态。此外,在子 程序中,还运用了嵌套的SeIeCt