ExcelVBA编程常用实例150例

上传人:仙*** 文档编号:89714775 上传时间:2022-05-13 格式:DOC 页数:59 大小:981KB
返回 下载 相关 举报
ExcelVBA编程常用实例150例_第1页
第1页 / 共59页
ExcelVBA编程常用实例150例_第2页
第2页 / 共59页
ExcelVBA编程常用实例150例_第3页
第3页 / 共59页
点击查看更多>>
资源描述
Excel VBA编程常用实例(150例)主要内容和特点ExcelVBA编程入门范例主要是以一些基础而简短的VBA实例来对ExcelVBA中的常用对象及其属性和方法进行讲解, 包括应用程序对象、窗口、工作簿、 工作表、单元格和单元格区域、图表、数据透视表、形状、控件、菜单和工具栏、 帮助助手、格式化操作、文件操作、以及常用方法和函数及技巧等方面的应用示 例。这些例子都比较基础,很容易理解,因而,很容易调试并得以实现,让您通 过具体的实例来熟悉ExcelVBA编程。分16章共14个专题,以具体实例来对大多数常用的ExcelVBA对象进行讲解; 一般而言,每个实例都很简短,用来说明使用VBA实现Excel某一功能的操作;各章内容主要是实例,即 VBA代码,配以简短的说明,有些例子可能配以必 要的图片,以便于理解;您可以对这些实例进行扩充或组合,以实现您想要的功能或更复杂的操作。VBE编辑器及VBA代码输入和调试的基本知识在学习这些实例的过程中,最好自已动手将它们输入到 VBE编辑器中调试运行, 来查看它们的结果。当然,您可以偷赖,将它们复制/粘贴到代码编辑窗口后,进行调试运行。下面,对VBE编辑器界面进行介绍,并对VBA代码输入和调试 的基本知识进行简单的讲解。激活VBE编辑器一般可以使用以下三种方式来打开 VBE编辑器:使用工作表菜单 工具一一宏一一Visual Basic编辑器”命令,如图00-01所示; 在Visual Basic 工具栏上,按 “ Visual Basic编辑器”按钮,如图00-02所示; 按Alt+F11组合键。1拼垢祎杳F7螳宋体* 12 -洁息检索 Alt+Click错误检査妙HI1 1K语音QP共享工作区(U),.共享工作濟(S).俺订叱较和合并工作薄址J,.保护 联机协作劈a冷单變量求解也)方案公式审檢Q!)k|宏龜)F宏血)Alt+F3加羲宏一录制新宏-自动更正选项(A).安全性自定文Vi snal Basic編辑器电)KLt+fll选项(丨 15Microsoft脚本编揖器(S)Ut+Shit+Fli-图00-01 :选择菜单 工具宏Visual Basic 编辑器”命令来打开 VBE编辑 器Visualc X/安全圧3Vi glial Ea i c 编辑器 |图00-02 :选择Visual Basic工具栏上的“Visual Basic编辑器”命令按钮来打开 VBE编辑器此外,您也可以使用下面三种方式打开 VBE编辑器:在任一工作表标签上单击鼠标右键, 在弹出的菜单中选择 查看代码”,则可 进入VBE编辑器访问该工作表的代码模块,如图00-03所示;在工作簿窗口左上角的Excel图标上单击鼠标右键,在弹出的菜单中选择 查看代码”,则可进入VBE编辑器访问活动工作簿的ThisWorkbook代码模块, 如图00-04所示;选择菜单 工具一一宏一一宏”命令打开宏对话框,若该工作簿中有宏程序, 则单击该对话框中的 编辑”按钮即可进行VBE编辑器代码模块,如图00-05所 示O插入g)卜 删除)重命名迅)移动或复制工作表地)选定全部工作表g)工作表标签颤色).申査看牝码过p H | Sheet l-SHeet/Sheet图00-03 :右击工作表标签弹出菜单并选择 查看代码”打开VBE编辑器:Sj文件迈)编辑觇3#图00-04 :右击Excel图标弹出菜单并选择 查看代码”打开VBE编辑器#图00-05 :在宏对话框中单击 编辑”按钮打开VBE编辑器VBE编辑器窗口简介刚打开VBE编辑器时,所显示的窗口如图00-06所示,其中没有代码模块窗口#転Mcroioft Visual Basic - Bookl文件iE 躺视圉世)JA 駁 脱 茹 IS夕區程序 窗口 鮒更性-SheetlXSheetl Worksheet(湍)Shsitl7J图00-06 :刚打开VBE编辑器时的窗口可以在 工程资源管理器”中双击任一对象打开代码窗口,或者选择菜单 插入一- 模块”或插入一一类模块”来打开代码窗口。一般VBE编辑器窗口及各组成部件 名称如图00-07所示,可以通过 视图菜单中的菜单项选择所出现的窗口。同时, 可以在工程属性”窗口中设置或修改相应对象的属性。Microsoft Visual Basic - BqdIcI -税块1 (代码)标题栏菜单栏 *亠-=-.疇 文件世) 骗辑 视冏豹 插人 稻式边 调iSQ)运行 工具 外接诫脣程 VBAPrujEct匸具|礎用了Opt i 4n Explici 件衣对 如 E) B*Frojt Ooin- fli-i .1-.驭丄?Jgl 閉 1 heet,l Gh.eetl) j H圜弘泗谊(ShsutZ) g Shect3 Gkest3) Thiorkbfiok二:鬥根块 丄一谟棋块1 主沾奕複块 一一类1当前工作簿对象代码模块类模块,匸程资源管理器窗口代码模块簡5#器称EUgflI:程属性窗口图00-07 : VBE编辑器窗口下面是带有用户窗体的 VBE编辑器窗口,如图00-08所示。选择VBE菜单插 入一一用户窗体”即可插入一个用户窗体。当插入用户窗体后,在 工程资源管理器”窗口中会出现一个用户窗体对象, 工程属性”窗口显示当前用户窗体的属性, 可对相关属性进行设置或修改。同时,在用户窗体上用鼠标单击,会出现控件工具箱”在工程资源管理器”窗口双击用户窗体图标,会出现相应的用户窗体; 在用户窗体图标或者是在用户窗体上单击鼠标右键,然后在弹出的菜单中选择 查看代码”,则会出现用户窗体代码窗口。齿 Microsoft: Visual Basic - Baokl - UerForrti l (Liserl-arm) 如前所述,您可以选择VBE菜单 插入一一用户窗体/模块/类模块”来插入模块或 用户窗体以及相应的代码窗口。此外,您也可以在 工程资源管理器”中单击鼠标 右键,从弹出的菜单中选择 插入一一用户窗体/模块/类模块”来实现上面的操作。 在获取相应的代码模块窗口后,就可以输入 VBA代码了。文件 舗辑 讽国 插入(I)搐式防 调试 运行 工具外按程序国口述凶.J 腿 VBAProjecl (BoqLI)匚Microsof t Ek ceT 対象L 3 Sheet! tsheetl) Sj Shat2 tShtctZ) | 塹 ShetS (ShetS)Tit i stf orkt o ok遏 UbrFormi忸.Hl户窗体对製【处由扯小相应京却 单击右谜比述聲液单UserForml曰“禽模壤i点槿块1 -浴类模块31HH亠ra-LlerFormlT艸甘代碍”权F代码韶4)VserFar*! Us1器称了UseiF oirinilJL.BaddColor口 moooooo?& ajoooooi2&BorderStyle0 - fnBor darS tylNc:Cap li onUserFwihl紬姐窗体叙曽ErbXedTruftFflut采晖FirtCftlor AH0oooooi2aHe i ghtisoMelpC craitK tlD0JKe epSerallJsrsVisibls 3 一 fmGtyr olLB aiEEo-tLsft0Honsalcon(Norte)MonsftPointer - fmMtiUsePointer!Fi dLureCNoike)Pi ctur eAli gnmezit.2 一 mP c tur e Al i 石mPi ctur SizMod0 r mPi ctureSizeMPi ctxur tillinir .V .按宇母序|按分类序|an图00-08 : VBE编辑器窗口(带有用尸窗体) 在VBE编辑器中输入VBA代码在VBE编辑器的代码模块中输入 VBA代码,通常有以下几种方法:手工键盘输入;使用宏录制器,即选择菜单 工具一一宏一一录制新宏”命令,将所进行的操作 自动录制成宏代码;复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中;导入代码模块,即在VBE编辑器中选择菜单 文件一一导入文件”或在工程资 源管理器”的任一对象上右击鼠标选择菜单 导入文件”,选择相应的代码文件导入。 如果不想要某个模块了,可以选择菜单 文件一一移除模块”也可以在相应的模 块上单击鼠标右键,从弹出的菜单中选择 移除模块”此时,会弹出一个警告框, 询问在移除模块前是否将其导出,可以根据需要进行选择。也可以选择菜单 文件 导出文件”或在相应的模块上单击鼠标右键后,从弹出 的菜单中选择 导出文件”将移除的模块保存在相应的文件夹中。这样,以后可 以对其进行导入,从而加以利用。调试VBA代码在VBE编辑器的菜单中,有两项与调试运行有关的菜单项,即调试”菜单和 运行”菜单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常 用到的有以下几个:逐语句。可以按F8键对代码按顺序一条一条语句运行,从而找出语句或逻辑 错误。设置断点。在可能存在问题的语句处设置断点 (可通过在相应代码前的空白部 位单击,将会出现一个深红色的椭圆即断点),当程序运行至断点处时,会中止 运行。在语句的适当部位设置 Debug.Print语句,运行后其结果会显示在 立即窗口 ” 中,可以此测试或跟踪变量的值。在立即窗口 ”中测试。对值的测试或跟踪,也可以以 ? ”开头,在 立即窗口 ” 中输入需要测试值的语句,按Enter回车键后将立即出现结果;对执行语句的测 试,可直接在 立即窗口 ”中输入,按Enter回车键后将执行。可以按F5键直接运行光标所在位置的子程序。在执行程序后,必须在Excel工作表中查看所得到的结果。可以用鼠标单击VBE编辑器左上角的Excel图标或者是按Alt+F11组合键切换到Excel界面。(当然,对程序代码的调试有很多方法和技巧,留待以后对VBA进一步研究和理解更透彻后一并讨论。)利用VBA帮助系统如果遇到疑问或错误,可以利用 Excel自带的VBA帮助系统。可以在如图00-09所示的部位输入需要帮助的关键词,按Enter回车键后将会 出现相关主题。用鼠标单击相应的主题即会出现详细的帮助信息。T 图00-09 :帮助搜索窗口可以按F2键,调出 对象浏览器”窗口(如图00-10所示),在搜索文本框中输 入需要帮助的关键词,将会在 搜索结果”中出现一系列相关的对象及方法、属性列表,单击相应的对象则会在 类”和成员”列表框中显示相应的对象和万法、属 性成员列表,在成员列表中相应的项目上按F1键即会出现详细的帮助信息。(对 象浏览器”是一个很好的帮助工具,值得好好研究)齿 Microsoft Visual Basic - EtMkl -对aS瞥丈件d)编需退)视圏 粧入榕式固调诃Q)运行(W 工旦夕卜摄程序 窗口址)帮助国巳丨為卷畤0忖鮭,瞪歹智贷丨 ,搜索框EL 尊 VSAlraject (Bookl)rs oft Excel 对象 Sheeil (She e-tl)Eh 讥2 (Sha2)Shee+3 (SheO)Th; slW or fcli oic k2岂西.釦一,1iS:-SheetlShee tlDiEplayFigeBrealffEFfilgeDiplyFigktloLftfalseEniblskutcFiltsrFelEEnaJbleCalculati onTriwEjtbleOuili 皿 ing:falseEnaileFivotTable?al3eEnbl gS elec ti on01 IHoEestxi ct 1 orisNan沁Shat1ScrSt4ndardtti.ith8.38isible-1 - xlSLe&tYiille按宇母序I按分类序I有库Ex celAi-LowEili纸 EmcI |f Esccl 取 ExcelExcL 纸 EycL 纸 ExcL 纸 ExL奠巴ffiiffl團mififfi血也fflffl血应曲整0:局Addincardilswerffz rar JF1Xppli cation hreasAulcCorrtct AntiFilt&r AiloRscfivrClass AJlowidi tog肚心电1的咸昂旧窮口Ltl龙4tRangae龙J Trotection芒 7findow5AutcCorrect曲 PivTitFi ld 边 JivotTatlc t*A ListObj ect 規P z + T mAll*wE ditE.w 的戍词述 ChngsFa.E 5*ar d ,:沧 Helf It由 Titl;血 Utipr oiect叫 Users选屮某成安即出现相爪图00-10 :对象浏览器窗口 参考资料ExcelVBA编程入门范例参考或引用了以下书籍和资料:Excel 2003高级VBA编程宝典Excel 2003与VBA编程从入门到精通仲文版) 巧学巧用Excel 2003 VBA 与宏(中文版) (4)ExcelVBA应用程序专业设计实用指南ExcelVBA应用开发与实例精讲(6) 一些网上资源 更多的信息关于ExcelVBA的更多参考和学习资源,可以在 上查找, 有疑问也可以在ExcelHome论坛中提问。您也可以登录我的博客 ,上面有很多Excel的学习资料。同时,欢迎与我联系交流, 我的 e-mail 是:xhdsxfjy。学习Excel,使用VBA对Excel进行控制操作是我很热衷的业余爱好之一。”fanjy第一章Excel应用程序对象(Application 对象)及其常用方法基本操作应用示例分类:ExcelVBAExcelVBA 编程入门范例Application对象代表整个 Microsoft Excel应用程序,带有175个属性和52个 方法,可以设置整个应用程序的环境或配置应用程序。示例01-01 :体验开/关屏幕更新(ScreenUpdating 属性)Sub关闭屏幕更新()MsgBox 顺序切换工作表 Sheet1 Sheet2 Sheet3 Sheet2,先开启屏幕 更新,然后关闭屏幕更新Worksheets(1).SelectMsgBox 目前屏幕中显示工作表 Sheet1Applicati on .Scree nUpdat ing = TrueWorksheets (2).SelectMsgBox 显示 Sheet2 了吗? ”Worksheets (3).SelectMsgBox 显示 Sheet3 了吗? ”Worksheets (2).SelectMsgBox 下面与前面执行的程序代码相同,但关闭屏幕更新功能Worksheets(1).SelectMsgBox 目前屏幕中显示工作表Sheet1 & Chr(10) & 关屏屏幕更新功能Applicati on .Scree nUpdat ing = FalseWorksheets (2).SelectMsgBox 显示 Sheet2 了吗? ”Worksheets (3).SelectMsgBox 显示 Sheet3 了吗? ”Worksheets (2).SelectApplicati on .Scree nUpdat ing = TrueEnd Sub示例说明:Scree nUpdat ing属性用来控制屏幕更新。当运行一个宏程序处理涉 及到多个工作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CPU的处理时间,从而降低程序的运行速度,而关闭该属性则可显著提高程序运行 速度。示例01-02 :使用状态栏(StatusBar属性)Sub testStatusBar()Applicatio n.DisplayStatusBar = True 开启状态栏显示赋值状态栏显示的文本Applicatio n.StatusBar = http:/fanjy.blog.excelhome.n etEnd Sub示例说明:StatusBar属性用来指定显示在状态栏上的信息。若不想再显示状态 栏文本,可使用Application.StatusBar = False语句关闭状态栏显示,也可以在程序开始将原先的状态栏设置存储,如使用语句oldStatusBar = Applicatio n.DisplayStatusBar将状态栏原来的信息存储在变量oldStatusBar,在程序运行完成或退出时,将变量重新赋值给状态栏,如使用语句Applicatio n.DisplayStatusBar = oldStatusBar,以恢复状态栏原状。示例01-03 :处理光标(Cursor属性)Sub ViewCursors()Applicati on .Cursor = xlNorthwestArrowMsgBox 您将使用箭头光标,切换到Excel界面查看光标形状Applicati on .Cursor = xlIBeamMsgBox 您将使用工形光标,切换到Excel界面查看光标形状Applicati on .Cursor = xlWaitMsgBox 您将使用等待形光标,切换到Excel界面查看光标形状Applicati on .Cursor = xlDefaultMsgBox 您已将光标恢复为缺省状态End Sub示例01-04 :获取系统信息Sub GetSystemInfo()MsgBox Excel 版本信息为:& Application.CalculationVersionMsgBox Excel 当前允许使用的内存为:& Application.MemoryFreeMsgBox Excel 当前已使用的内存为:& Application.MemoryUsedMsgBox Excel 可以使用的内存为:& Application.MemoryTotalMsgBox 本机操作系统的名称和版本为:& Application.OperatingSystemMsgBox 本产品所登记的组织名为:& Application.OrganizationNameMsgBoxMsgBox End Sub 示例说明:当前用户名为:& Application.UserName当前使用的 Excel 版本为:& Application.Version可以使用给UserName属性赋值以设置用户名称。示例01-05 :退出复制/剪切模式(CutCopyMode 属性)Sub exitCutCopyMode()Applicati on .CutCopyMode = FalseEnd Sub示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会 在原单元格区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用 Applicatio n. CutCopyMode = False语句恢复该属性的默认设置。示例01-06 :禁止弹出警告信息(DisplayAlerts 属性)Sub testAlertsDisplay()Applicatio n.DisplayAlerts = FalseEnd Sub示例说明:在程序运行过程中,有时由于Excel本身设置的原因,会弹出对话框, 从而中断程序的运行,您可以在程序之前加上Applicatio n.DisplayAlerts = False语句以禁止弹出这些对话框而不影响程序正常运行。需要注意的是,在程序 运行结束前,应使DisplayAlerts属性恢复为缺省状态,即使用语句Application.DisplayAlerts = True 。该属性的默认设置为True,当将该属性设置为False时, Excel会使直接使用对话框中默认的选择,从而不会因为弹出对话框而影响程序 运行。示例01-07 :将Excel全屏幕显示Sub testFullScree n()MsgBox 运行后将Excel的显示模式设置为全屏幕Applicatio n.DisplayFullScree n = TrueMsgBox 恢复为原来的状态Applicatio n.DisplayFullScree n = FalseEnd Sub示例01-08 : Excel启动的文件夹路径Sub ExcelStartfolder()MsgBox Excel 启动的文件夹路径为:& Chr(10) & Applicatio n. StartupPa thEnd Sub示例01-09 :打开最近使用过的文档Sub Ope nRece ntFiles()MsgBox 显示最近使用过的第三个文件名,并打开该文件MsgBox 最近使用的第三个文件的名称为 :& Application.RecentFiles(3).N ameApplicatio n.Rece ntFiles(3).Ope nEnd Sub示例01-10 :打开文件(FindFile方法)Sub Fin dFileOpe n()On Error Resume NextMsgBox 请打开文件, vbOKOnly + vblnformation,打开文件If Not Application.FindFile ThenMsgBox 文件未找到, vbOKOnly + vblnformation,打开失败End IfEnd Sub示例说明:本示例将显示 打开”文件对话框,若用户未打开文件(即点击 取消”按 钮),则会显示打开失败”信息框。示例中使用了 FindFile方法,用来显示打开” 对话框并让用户打开一个文件。如果成功打开一个新文件,则该值为True。如果用户取消了操作并退出该对话框,则该值为 False。示例01-11 :文件对话框操作(FileDialog属性)Sub UseFileDialogOpe n()Dim In gCo unt As Long开启打开文件对话框With Applicati on. FileDialog(msoFileDialogOpe n).AIIowMultiSelect = True.Show显示所选的每个文件的路径For In gCo unt = 1 To .SelectedItems.Co untMsgBox .SelectedItems(l ngCou nt)Next l ngCou ntEnd WithEnd Sub示例说明:本示例显示 打开文件”寸话框,当用户在其中选择一个或多个文件后, 将依次显示每个文件的路径。其中,FileDialog属性返回打开和保存对话框中一 系列对象的集合,您可以对该集合对象的属性进行进一步的设置,如上例中的A llowMultiSelect属性设置为True将允许用户选择多个文件。示例01-12 :保存Excel的工作环境Sub保存Excel的工作环境()MsgBox 将Excel的工作环境保存到中Applicatio n.SaveWorkspace D:ExcelSampleSampleEnd Sub示例说明:运行本程序后,将工作簿以带后缀名.xlw保存到D盘的ExcelSampl e文件夹中,生成的文件全名为 Sample.xlw。当改变工作簿并保存时,Excel 会询问是覆盖原文件还是保存副本。示例01-13 :改变Excel工作簿名字(Caption属性) Sub SetCaptio n()13Applicatio n.Cap ti on = My ExcelBookEnd Sub示例说明:运行本程序后,将工作簿左上角Excel图标右侧的“Microsoft Excel改为 “My ExcelBook。示例01-14 :使用InputBox 方法Sub SampleI nputBox()Dim vln putvInput = InputBox( 请输入用户名:,获取用户名, Application.UserName)MsgBox 您好!& vlnput & .很高兴能认识您.,vbOKOnly,打招呼End Sub示例01-15 :设置页边距(CentimetersToPoints方法)Sub SetLeftMargi n()MsgBox 将工作表Sheet1的左页边距设为5厘米Worksheets(Sheet1).PageSetup 丄 eftMargin = Applicatio n.Cen timetersTo Poi nts(5) End Sub示例 01-16 :使用 Windows 的计算器(ActivateMicrosoftApp 方法) Sub CallCalculate()Applicati on. ActivateMicrosoftApp In dex:=0End Sub示例说明:运行本程序后,将调用 Windows的计算器。示例01-17 :在程序中运行另一个宏(Run方法)Sub run OtherMacro()MsgBox 本程序先选择A1至C6单元格区域后执行 DrawLine宏ActiveSheet.Ra nge(A2:C6).SelectApplicati on.Run DrawLi neEnd Sub示例01-18 :在指定的时间执行宏(OnTime方法)Sub AfterTimetoRu n()MsgBox 从现在开始,10秒后执行程序testFullScreenApplicatio n.On Time Now + TimeValue(00:00:10), testFullScree n End Sub示例说明:运行本程序后,在10秒后将执行程序testFullScreen。示例01-19 :暂时停止宏运行(Wait方法)Sub Stop5sMacroRu n()Dim SetTime As DateMsgBox 按下确定,5秒后执行程序testFullScreenSetTime = DateAdd(s, 5, Now()15Applicati on. Wait SetTimeCall testFullScree nEnd Sub示例说明:运行本程序后,按下弹出的提示框中的确定”按钮,等待5秒后执行另一程序 testFullScreen。示例01-20 :按下指定的按键后执行程序(OnKey方法)示例 01-20-1Sub PressKeytoRu n()MsgBox 按下 Ctrl+D 后将执行程序testFullScreenApplicatio n.On Key Ad, testFullScree nEnd Sub示例 01-20-2Sub ResetKey()MsgBox 恢复原来的按键状态Applicatio n.On Key dEnd Sub示例说明:Onkey方法的作用主要是指定特定的键,当按下指定的键时运行相 应的宏程序,或者按下指定的键时,使Excel屏蔽特定的功能。示例01-21 :重新计算工作簿示例 01-21-1Sub CalculateAllWorkbook()Applicatio n.CalculateEnd Sub示例说明:当工作簿的计算模式被设置为手动模式后,运用Calculate方法可以重新计算所有打开的工作簿、工作簿中特定的工作表或者工作表中指定的单元格 区域。示例 01-21-2Sub CalculateFullSample()If Application.CalculationVersion Workbooks(1).CalculationVersion ThenApplicati on. CalculateFullEnd IfEnd Sub示例说明:本示例先将当前 Microsoft Excel的版本与上次计算该工作簿的Excel版本进行比较,如果两个版本不同,则对所有打开工作簿中的数据进行一次完 整计算。其中,CalculationVersion属性返回工作簿的版本信息。示例01-22 :控制函数重新计算(Volatile方法) Fun ction Non StaticRa nd()当工作表中任意单元格重新计算时本函数更新Application.Volatile TrueNon StaticRa nd = Rnd()#End Fun cti on示例说明:本示例摸仿 Excel中的Rand()函数,当工作表单元格发生变化时,都会重新计算该函数。在例子中,使用了 Volatile方法,强制函数进行重新计算,即无论何时重新计算工作表,该函数都会重新计算。示例01-23 :利用工作表函数(WorksheetFunction属性)Sub WorksheetF un ctio nSample()Dim myRa nge As Ran ge, an swerSet myRa nge = Worksheets(Sheet1).Ra nge(A1:C10)an swer = Applicatio n. WorksheetF un ctio n.Mi n(m yRa nge)MsgBox an swerEnd Sub示例说明:本示例获取工作表 Sheet1中单元格区域A1:C10中的最小值,使用 了工作表函数Min()。一般,使用 WorksheetFunction属性引用工作表函数,但 如果VBA自带有实现相同功能的函数,贝U直接使用该函数,否则会出现错误。示例01-24 :获取重叠区域(Intersect方法)Sub In tersectRa nge()Dim rSect As RangeWorksheets(Sheet1).ActivateSet rSect = Application.Intersect(Range(rg1), Range(rg2)If rSect Is Nothi ng The nMsgBox 没有交叉区域ElserSect.SelectEnd IfEnd Sub示例说明:本示例在工作表Sheet1中选定两个命名区域rg1和rg2的重叠区域, 如果所选区域不重叠,则显示一条相应的信息。其中,In tersect方法返回一个R ange对象,代表两个或多个范围重叠的矩形区域。示例01-25 :获取路径分隔符(PathSeparator属性)Sub GetPathSeparator()MsgBox 路径分隔符为& Application.PathSeparator End Sub示例说明:本示例使用PathSeparator属性返回路径分隔符(“。”) 示例01-26 :快速移至指定位置(Goto方法)Sub GotoSample()Application.Goto Reference:=Worksheets(Sheet1).Range(A154), _ scroll:=TrueEnd Sub示例说明:本示例运行后,将当前单元格移至工作表 Sheet1中的单元格A15417示例01-27 :显示内置对话框(Dialogs属性)Sub DialogSample()Applicatio n.Dialogs(xlDialogOpe n).ShowEnd Sub示例说明:本示例显示 Excel的打开”文件对话框。其中,Dialogs属性返回的 集合代表所有的Excel内置对话框。示例 01-28 :退出 Excel(SendKeys 方法)Sub Sen dKeysSample()Applicatio n.Se ndKeys (%fx)End Sub示例说明:本示例使用SendKeys方法退出Excel,若未保存,则会弹出提示对 话框并让用户作出相应的选择。SendKeys方法的作用是摸拟键盘输入,如例中 的“fx”示在Excel中同时按下Alt、F和X三个键。示例01-29 :关闭ExcelSub 关闭 Excel()MsgBox Excel 将会关闭Applicati on .QuitEnd Sub示例说明:运行本程序后,若该工作簿未保存,则会弹出对话框询问是否保存(by fanjy)第二章窗口(Window对象)基本操作应用示例(一)分类:ExcelVBAExcelVBA 编程入门范例Window对象代表一个窗口,约有48个属性和14个方法,能对窗口特性进行设 置和操作。Window对象是 Windows集合中的成员,对于Application对象来说, Windows集合包含该应用程序中的所有窗口;对于 Workbook对象来说,Wind ows集合只包含指定工作簿中的窗口。下面介绍一些示例,以演示和说明Window对象及其属性和方法的运用。示例02-01 :激活窗口 (Activate方法) Sub SelectWi ndow()Dim iWin As Lon g, i As Long, bWinMsgBox 依次切换已打开的窗口 iWin = Win dows.Cou ntMsgBox “您已打开的窗口数量为:” & iWinFor i = 1 To iWi nWin dows(i).ActivatebWin = MsgBox(您激活了第& i & 个窗口,还要继续吗? , vbYesNo)If bWin = vbNo Then Exit SubNext iEnd Sub示例02-02 :窗口状态(WindowState 属性)示例 02-02-01Sub Win dowStateTest()MsgBox 当前活动工作簿窗口将最小化Win dows(1).Wi ndowState = xlMi nimizedMsgBox 当前活动工作簿窗口将恢复正常Win dows(1).Wi ndowState = xlNormalMsgBox 当前活动工作簿窗口将最大化Win dows(1).Wi ndowState = xlMaximizedEnd Sub示例说明:使用 WindowState属性可以返回或者设置窗口的状态。示例中,常量 xlMinimized、xlNormal 和 xlMaximized 分别代表窗口不同状态值, Windows (1)表示当前活动窗口。可以使用 Windows(index)来返回单个的 Window对象, 其中的index为窗口的名称或编号,活动窗口总是 Windows(1)。示例 02-02-02Sub testWi ndow()测试Excel应用程序窗口状态MsgBox 应用程序窗口将最大化Applicati on.Win dowState = xlMaximizedCall testWi ndowStateMsgBox 应用程序窗口将恢复正常Applicati on.Win dowState = xlNormalMsgBox 应用程序窗口已恢复正常测试活动工作簿窗口状态MsgBox 当前活动工作簿窗口将最小化ActiveWi ndow.Wi ndowState = xlMi nimizedCall testWi ndowStateMsgBox 当前活动工作簿窗口将最大化ActiveWi ndow.Wi ndowState = xlMaximizedCall testWi ndowStateMsgBox 当前活动工作簿窗口将恢复正常ActiveWi ndow.Wi ndowState = xlNormalCall testWi ndowStateMsgBox 应用程序窗口将最小化Applicatio n.Win dowState = xlMi ni mizedCall testWi ndowStateEnd Sub*Sub testWi ndowState()Select Case Applicati on.Win dowStateCase xlMaximized: MsgBox 应用程序窗口已最大化Case xlMinimized: MsgBox 应用程序窗口已最小化Case xlNormal:Select Case ActiveWindow.WindowStateCase xlMaximized: MsgBox 当前活动工作簿窗口已最大化Case xlMinimized: MsgBox 当前活动工作簿窗口已最小化Case xlNormal: MsgBox 当前活动工作簿窗口已恢复正常End SelectEnd SelectEnd Sub示例说明:本示例有两个程序,其中testWindow()是主程序,调用子程序textWindowState(),演示了应用程序窗口和工作簿窗口的不同状态。当前活动窗口 一般代表当前活动工作簿窗口,读者可以在VBE编辑器中按F8键逐语句运行testWindow()程序,观察Excel应用程序及工作簿窗口的不同状态。此外,在子 程序中,还运用了嵌套的 Select Case结构。示例 02-02-03Sub SheetGradualGrow()Dim x As In tegerWith ActiveWi ndow.Win dowState = xlNormal.Top = 1丄 eft = 1.Height = 50.Width = 50For x = 50 To Applicati on .UsableHeight.Height = xNext xFor x = 50 To Applicatio n.UsableWidth.Width = xNext x.Win dowState = xlMaximizedEnd WithEnd Sub示例说明:本示例将动态演示工作簿窗口由小到大直至最大化的变化过程。在运行程序时,您可以将 VBE窗口缩小,从而在工作簿中查看动态效果,也可以在 Excel中选择菜单中的宏命令执行以查看效果。示例02-03 :切换显示工作表元素示例 02-03-01Sub testDisplayHead in g()MsgBox “切换显示/隐藏行列标号”ActiveWi ndow.DisplayHeadi ngs = Not ActiveWi ndow.DisplayHeadi ngs End Sub示例说明:本示例切换是否显示工作表中的行列标号。运行后,工作表中的行标号和列标号将消失;再次运行后,行列标号重新出现,如此反复。您也可以将该 属性设置为False,以取消行列标号的显示,女口ActiveWindow.DisplayHeadings = False ;而将该属性设置为True,则显示行列标号。示例 02-03-02Sub testDisplayGridli ne()MsgBox “切换显示/隐藏网格线”ActiveWi ndow.DisplayGridli nes = Not ActiveWi ndow.DisplayGridl in es End Sub示例说明:本示例切换是否显示工作表中的网格线。 运行后,工作表中的网格线 消失,再次运行后,网格线重新出现,如此反复。您也可以将该属性设置为False,以取消网格线显示,女口 ActiveWindow.DisplayGridlines = False ;而将该属 性设置为True,则显示网格线。示例 02-03-03Sub DisplayHorizo ntalScrollBar()MsgBox “切换显示/隐藏水平滚动条”ActiveWi ndow.DisplayHorizo ntalScrollBar =_Not ActiveWi ndow.DisplayHorizo ntalScrollBarEnd Sub示例说明:本示例切换是否显示工作表中的水平滚动条。运行后,工作表中的水平滚动条消失,再次运行后,水平滚动条重新出现,如此反复。您也可以将该属 性设置为 False,以取消水平滚动条,女口 ActiveWindow.DisplayHorizontalScrol lBar = False ;而将该属性设置为True,则显示水平滚动条。同理,DisplayVerticalScrollBar属性将用来设置垂直滚动条。示例 02-03-04Sub DisplayScrollBar()MsgBox 切换显示/隐藏水平和垂直滚动条Applicatio n.DisplayScrollBars = Not (Applicatio n.DisplayScrollBars) End Sub示例说明:本示例切换是否显示工作表中的水平和垂直滚动条。运行后,工作表中的水平和垂直滚动条同时消失,再次运行后,水平和垂直滚动条重新出现,如此反复。您也可以将该属性设置为False,以取消水平和垂直滚动条显示,如 Application.DisplayScrollBars= False;而将该属性设置为 True,则显示水平和垂直滚动条。示例02-04 :显示公式(DisplayFormulas 属性)Sub DisplayFormula()MsgBox “显示工作表中包含公式的单元格中的公式 ”ActiveWi ndow.DisplayFormulas = TrueEnd Sub示例说明:本程序运行后,工作表中含有公式的单元格将显示公式而不是数值。21若要显示数值,则将该属性设置为False,或者,如果工作表中的公式显示的是结果数值,则该属性为False。示例02-05 :显示/隐藏工作表标签(DisplayWorkbookTabs 属性)Sub testDisplayWorkbookTab()MsgBox “隐藏工作表标签”ActiveWi ndow.DisplayWorkbookTabs = FalseEnd Sub示例说明:本程序运行后,工作表标签消失。将该属性设置为True,重新显示工作表标签。示例02-06 :命名活动窗口 (Caption属性)Sub testCaptio n()MsgBox 当前活动工作簿窗口的名字是:& ActiveWindow.CaptionActiveWorkbook.Windows(1).Caption = ”我的工作簿”MsgBox 当前活动工作簿窗口的名字是:& ActiveWindow.Caption End Sub示例说明:本程序运行后,显示当前活动工作簿窗口原先的名称(即工作簿窗口未处于最大化状态时,出现在窗口顶部标题栏中的文字),然后设置当前活动工作簿窗口名称,即使用语句 ActiveWorkbook.Wi ndows(1).Capti on = 我的工作 簿,最后显示当前活动工作簿窗口的新名称。改变窗口的标题并不会改变工作 簿的名称。示例02-07 :移动窗口到指定位置(ScrollRow 属性和ScrollColumn 属性) Sub testScroll()MsgBox “将当前窗口工作表左上角单元格移至第10行第3列
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!