首页 Excel VBA编程入门范例

Excel VBA编程入门范例

举报
开通vip

Excel VBA编程入门范例Excel+VBA编程入门范例 http://www.tt198.net/ 2006年9月7日http://fanjy.-1-blog.excelhome.net 前言 很喜爱VBA,喜欢使用她对Excel操作实现所需的功能,更喜欢使用VBA控制Excel以及 实现结果后的那种感觉。 一直都想对ExcelVBA进行系统的整理和归纳,但由于对Excel及VBA了解得不够深入, 总觉得无从下手。再加上又是利用少得可怜的业余时间进行学习,时断时续,学习的主线和 思路也经常因为工作或其它的事情而打断。但喜欢学习的人总会挤得...

Excel VBA编程入门范例
Excel+VBA编程入门范例 http://www.tt198.net/ 2006年9月7日http://fanjy.-1-blog.excelhome.net 前言 很喜爱VBA,喜欢使用她对Excel操作实现所需的功能,更喜欢使用VBA控制Excel以及 实现结果后的那种感觉。 一直都想对ExcelVBA进行系统的整理和归纳,但由于对Excel及VBA了解得不够深入, 总觉得无从下手。再加上又是利用少得可怜的业余时间进行学习,时断时续,学习的主线和 思路也经常因为工作或其它的事情而打断。但喜欢学习的人总会挤得出时间来的,要想掌握 或者是精通一门知识和技术不能有任何借口。幸运的是,有网络这个大平台,更有 ExcelHome众多网友的帮助和鼓励,这几个月,总算坚持了下来。对Excel的痴迷没有停 留在头脑和心中,而是体现在了具体的行动以及积极的学习和参与上来,因此,收获很大, 感觉水平也有明显的提高。 现在,我计划利用点滴的业余时间,将基本的ExcelVBA操作用简短的实例进行演示,编辑 成《ExcelVBA编程入门范例》,以此对ExcelVBA基础知识进行一次归纳和整理,从而理 清学习ExcelVBA的线条,同时也希望能对热衷于Excel的朋友以及ExcelVBA初学者快速 了解和步入ExcelVBA编程殿堂有所帮助。这是我第一次偿试对所学知识进行较大规模的整 理,希望大家能多提改进意见和建议,以利于改进和提高,也有助于以后的学习和编写出更 好的作品呈献给大家。 主要内容和特点 《ExcelVBA编程入门范例》主要是以一些基础而简短的VBA实例来对ExcelVBA中的常 用对象及其属性和 方法 快递客服问题件处理详细方法山木方法pdf计算方法pdf华与华方法下载八字理论方法下载 进行讲解,包括应用程序对象、窗口、工作簿、工作 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 、单元格和单 元格区域、图表、数据透视表、形状、控件、菜单和工具栏、帮助助手、格式化操作、文件 操作、以及常用方法和函数及技巧等方面的应用示例。这些例子都比较基础,很容易理解, 因而,很容易调试并得以实现,让您通过具体的实例来熟悉ExcelVBA编程。 ■分16章共14个专题,以具体实例来对大多数常用的ExcelVBA对象进行讲解; ■一般而言,每个实例都很简短,用来说明使用VBA实现Excel某一功能的操作; ■各章内容主要是实例,即VBA代码,配以简短的说明,有些例子可能配以必要的图 片,以便于理解; ■您可以对这些实例进行扩充或组合,以实现您想要的功能或更复杂的操作。 VBE编辑器及VBA代码输入和调试的基本知识 在学习这些实例的过程中,最好自已动手将它们输入到VBE编辑器中调试运行,来查看它 们的结果。当然,您可以偷赖,将它们复制/粘贴到代码编辑窗口后,进行调试运行。下面, 对VBE编辑器界面进行介绍,并对VBA代码输入和调试的基本知识进行简单的讲解。 激活VBE编辑器 一般可以使用以下三种方式来打开VBE编辑器: ■使用工作表菜单“工具——宏——VisualBasic编辑器”命令,如图00-01所示; ■在VisualBasic工具栏上,按“VisualBasic编辑器”按钮,如图00-02所示; ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-2-blog.excelhome.net ■按Alt+F11组合键。 图00-01:选择菜单“工具——宏——VisualBasic编辑器”命令来打开VBE编辑器 图00-02:选择VisualBasic工具栏上的“VisualBasic编辑器”命令按钮来打开VBE编辑器 此外,您也可以使用下面三种方式打开VBE编辑器: ■在任一工作表标签上单击鼠标右键,在弹出的菜单中选择“查看代码”,则可进入 VBE编辑器访问该工作表的代码模块,如图00-03所示; ■在工作簿窗口左上角的Excel图标上单击鼠标右键,在弹出的菜单中选择“查看代 码”,则可进入VBE编辑器访问活动工作簿的ThisWorkbook代码模块,如图00-04 所示; ■选择菜单“工具——宏——宏”命令打开宏对话框,若该工作簿中有宏程序,则单 击该对话框中的“编辑”按钮即可进行VBE编辑器代码模块,如图00-05所示。 ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-3-blog.excelhome.net 图00-03:右击工作表标签弹出菜单并选择“查看代码”打开VBE编辑器 图00-04:右击Excel图标弹出菜单并选择“查看代码”打开VBE编辑器 图00-05:在宏对话框中单击“编辑”按钮打开VBE编辑器 VBE编辑器窗口简介 刚打开VBE编辑器时,所显示的窗口如图00-06所示,其中没有代码模块窗口。 ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-4-blog.excelhome.net 图00-06:刚打开VBE编辑器时的窗口 可以在“工程资源管理器”中双击任一对象打开代码窗口,或者选择菜单“插入——模块” 或“插入——类模块”来打开代码窗口。一般VBE编辑器窗口及各组成部件名称如图00-07 所示,可以通过“视图”菜单中的菜单项选择所出现的窗口。同时,可以在“工程属性”窗 口中设置或修改相应对象的属性。 图00-07:VBE编辑器窗口 下面是带有用户窗体的VBE编辑器窗口,如图00-08所示。选择VBE菜单“插入——用 户窗体”,即可插入一个用户窗体。当插入用户窗体后,在“工程资源管理器”窗口中会出 现一个用户窗体对象,“工程属性”窗口显示当前用户窗体的属性,可对相关属性进行设置 或修改。同时,在用户窗体上用鼠标单击,会出现“控件工具箱”。在“工程资源管理器” 窗口双击用户窗体图标,会出现相应的用户窗体;在用户窗体图标或者是在用户窗体上单击 鼠标右键,然后在弹出的菜单中选择“查看代码”,则会出现用户窗体代码窗口。 ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-5-blog.excelhome.net 图00-08:VBE编辑器窗口(带有用户窗体) 在VBE编辑器中输入VBA代码 如前所述,您可以选择VBE菜单“插入——用户窗体/模块/类模块”来插入模块或用户窗 体以及相应的代码窗口。此外,您也可以在“工程资源管理器”中单击鼠标右键,从弹出的 菜单中选择“插入——用户窗体/模块/类模块”来实现上面的操作。在获取相应的代码模块 窗口后,就可以输入VBA代码了。 在VBE编辑器的代码模块中输入VBA代码,通常有以下几种方法: ■手工键盘输入; ■使用宏录制器,即选择菜单“工具——宏——录制新宏”命令,将所进行的操作自 动录制成宏代码; ■复制/粘贴代码,即将现有的代码复制后,粘贴到相应的代码模块中; ■导入代码模块,即在VBE编辑器中选择菜单“文件——导入文件”或在“工程资源 管理器”的任一对象上右击鼠标选择菜单“导入文件”,选择相应的代码文件导入。 如果不想要某个模块了,可以选择菜单“文件——移除模块”,也可以在相应的模块上单击 鼠标右键,从弹出的菜单中选择“移除模块”。此时,会弹出一个警告框,询问在移除模块 前是否将其导出,可以根据需要进行选择。 也可以选择菜单“文件——导出文件”或在相应的模块上单击鼠标右键后,从弹出的菜单中 选择“导出文件”,将移除的模块保存在相应的文件夹中。这样,以后可以对其进行导入, 从而加以利用。 调试VBA代码 在VBE编辑器的菜单中,有两项与调试运行有关的菜单项,即“调试”菜单和“运行”菜 ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-6-blog.excelhome.net 单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常用到的有以下几个: ■逐语句。可以按F8键对代码按顺序一条一条语句运行,从而找出语句或逻辑错误。 ■设置断点。在可能存在问题的语句处设置断点(可通过在相应代码前的空白部位单 击,将会出现一个深红色的椭圆即断点),当程序运行至断点处时,会中止运行。 ■在语句的适当部位设置Debug.Print语句,运行后其结果会显示在“立即窗口”中, 可以此测试或跟踪变量的值。 ■在“立即窗口”中测试。对值的测试或跟踪,也可以以“?”开头,在“立即窗口” 中输入需要测试值的语句,按Enter回车键后将立即出现结果;对执行语句的测试, 可直接在“立即窗口”中输入,按Enter回车键后将执行。 ■可以按F5键直接运行光标所在位置的子程序。 在执行程序后,必须在Excel工作表中查看所得到的结果。可以用鼠标单击VBE编辑器左 上角的Excel图标或者是按Alt+F11组合键切换到Excel界面。 (当然,对程序代码的调试有很多方法和技巧,留待以后对VBA进一步研究和理解更透彻后 一并讨论。) 利用VBA帮助系统 如果遇到疑问或错误,可以利用Excel自带的VBA帮助系统。 ■可以在如图00-09所示的部位输入需要帮助的关键词,按Enter回车键后将会出现 相关主题。用鼠标单击相应的主题即会出现详细的帮助信息。 图00-09:帮助搜索窗口 ■可以按F2键,调出“对象浏览器”窗口(如图00-10所示),在搜索文本框中输入需 要帮助的关键词,将会在“搜索结果”中出现一系列相关的对象及方法、属性列表, 单击相应的对象则会在“类”和“成员”列表框中显示相应的对象和方法、属性成 员列表,在成员列表中相应的项目上按F1键即会出现详细的帮助信息。(“对象浏 览器”是一个很好的帮助工具,值得好好研究) 图00-10:对象浏览器窗口 ExcelVBA>>ExcelVBA编程入门范例>>前言(fanjy) 2006年9月7日http://fanjy.-7-blog.excelhome.net 参考资料 《ExcelVBA编程入门范例》参考或引用了以下书籍和资料: (1)Excel2003高级VBA编程宝典 (2)Excel2003与VBA编程从入门到精通(中文版) (3)巧学巧用Excel2003VBA与宏(中文版) (4)ExcelVBA应用程序专业 设计 领导形象设计圆作业设计ao工艺污水处理厂设计附属工程施工组织设计清扫机器人结构设计 实用指南 (5)ExcelVBA应用开发与实例精讲 (6)一些网上资源 更多的信息 关于ExcelVBA的更多参考和学习资源,可以在www.excelhome.net上查找,有疑问也可 以在ExcelHome论坛中提问。您也可以登录我的博客http://fanjy.blog.excelhome.net,上 面有很多Excel的学习资料。同时,欢迎与我联系交流,我的e-mail是:xhdsxfjy@163.com。 “学习Excel,使用VBA对Excel进行控制操作是我很热衷的业余爱好之一。”——fanjy ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-1-blog.excelhome.net 第一章Excel应用程序对象(Application对象)及其常用方法 基本操作应用示例 Application对象代表整个MicrosoftExcel应用程序,带有175个属性和52个方法,可以 设置整个应用程序的环境或配置应用程序。 示例01-01:体验开/关屏幕更新(ScreenUpdating属性) Sub关闭屏幕更新() MsgBox"顺序切换工作表Sheet1→Sheet2→Sheet3→Sheet2,先开启屏幕更新,然后 关闭屏幕更新" Worksheets(1).Select MsgBox"目前屏幕中显示工作表Sheet1" Application.ScreenUpdating=True Worksheets(2).Select MsgBox"显示Sheet2了吗?" Worksheets(3).Select MsgBox"显示Sheet3了吗?" Worksheets(2).Select MsgBox"下面与前面执行的程序代码相同,但关闭屏幕更新功能" Worksheets(1).Select MsgBox"目前屏幕中显示工作表Sheet1"&Chr(10)&"关屏屏幕更新功能" Application.ScreenUpdating=False Worksheets(2).Select MsgBox"显示Sheet2了吗?" Worksheets(3).Select MsgBox"显示Sheet3了吗?" Worksheets(2).Select Application.ScreenUpdating=True EndSub 示例说明:ScreenUpdating属性用来控制屏幕更新。当运行一个宏程序处理涉及到多个工 作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CPU的处理时间,从而降 低程序的运行速度,而关闭该属性则可显著提高程序运行速度。 示例01-02:使用状态栏(StatusBar属性) SubtestStatusBar() Application.DisplayStatusBar=True'开启状态栏显示 '赋值状态栏显示的文本 Application.StatusBar="http://fanjy.blog.excelhome.net" EndSub 示例说明:StatusBar属性用来指定显示在状态栏上的信息。若不想再显示状态栏文本,可 使用Application.StatusBar=False语句关闭状态栏显示,也可以在程序开始将原先的状态 栏设置存储,如使用语句oldStatusBar=Application.DisplayStatusBar将状态栏原来的信息 存储在变量oldStatusBar,在程序运行完成或退出时,将变量重新赋值给状态栏,如使用语 句Application.DisplayStatusBar=oldStatusBar,以恢复状态栏原状。 ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-2-blog.excelhome.net 示例01-03:处理光标(Cursor属性) SubViewCursors() Application.Cursor=xlNorthwestArrow MsgBox"您将使用箭头光标,切换到Excel界面查看光标形状" Application.Cursor=xlIBeam MsgBox"您将使用工形光标,切换到Excel界面查看光标形状" Application.Cursor=xlWait MsgBox"您将使用等待形光标,切换到Excel界面查看光标形状" Application.Cursor=xlDefault MsgBox"您已将光标恢复为缺省状态" EndSub 示例01-04:获取系统信息 SubGetSystemInfo() MsgBox"Excel版本信息为:"&Application.CalculationVersion MsgBox"Excel当前允许使用的内存为:"&Application.MemoryFree MsgBox"Excel当前已使用的内存为:"&Application.MemoryUsed MsgBox"Excel可以使用的内存为:"&Application.MemoryTotal MsgBox"本机操作系统的名称和版本为:"&Application.OperatingSystem MsgBox"本产品所登记的组织名为:"&Application.OrganizationName MsgBox"当前用户名为:"&Application.UserName MsgBox"当前使用的Excel版本为:"&Application.Version EndSub 示例说明:可以使用给UserName属性赋值以设置用户名称。 示例01-05:退出复制/剪切模式(CutCopyMode属性) SubexitCutCopyMode() Application.CutCopyMode=False EndSub 示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会在原单元格 区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用Application.CutCopyMode 0 示例01-06:禁止弹出警告信息(DisplayAlerts属性) SubtestAlertsDisplay() Application.DisplayAlerts=False EndSub 示例说明:在程序运行过程中,有时由于Excel本身设置的原因,会弹出对话框,从而中断 程序的运行,您可以在程序之前加上Application.DisplayAlerts=False语句以禁止弹出这 些对话框而不影响程序正常运行。需要注意的是,在程序运行结束前,应使DisplayAlerts 属性恢复为缺省状态,即使用语句Application.DisplayAlerts=True。该属性的默认设置为 True,当将该属性设置为False时,Excel会使直接使用对话框中默认的选择,从而不会因 为弹出对话框而影响程序运行。 ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-3-blog.excelhome.net 示例01-07:将Excel全屏幕显示 SubtestFullScreen() MsgBox"运行后将Excel的显示模式设置为全屏幕" Application.DisplayFullScreen=True MsgBox"恢复为原来的状态" Application.DisplayFullScreen=False EndSub 示例01-08:Excel启动的文件夹路径 SubExcelStartfolder() MsgBox"Excel启动的文件夹路径为:"&Chr(10)&Application.StartupPath EndSub 示例01-09:打开最近使用过的文档 SubOpenRecentFiles() MsgBox"显示最近使用过的第三个文件名,并打开该文件" MsgBox"最近使用的第三个文件的名称为:"&Application.RecentFiles(3).Name Application.RecentFiles(3).Open EndSub 示例01-10:打开文件(FindFile方法) SubFindFileOpen() OnErrorResumeNext MsgBox"请打开文件",vbOKOnly+vbInformation,"打开文件" IfNotApplication.FindFileThen MsgBox"文件未找到",vbOKOnly+vbInformation,"打开失败" EndIf EndSub 示例说明:本示例将显示“打开”文件对话框,若用户未打开文件(即点击“取消”按钮),则会显 示“打开失败”信息框。示例中使用了FindFile方法,用来显示“打开”对话框并让用户打开一 个文件。如果成功打开一个新文件,则该值为True。如果用户取消了操作并退出该对话框, 则该值为False。 示例01-11:文件对话框操作(FileDialog属性) SubUseFileDialogOpen() DimlngCountAsLong '开启"打开文件"对话框 WithApplication.FileDialog(msoFileDialogOpen) .AllowMultiSelect=True .Show '显示所选的每个文件的路径 ForlngCount=1To.SelectedItems.Count MsgBox.SelectedItems(lngCount) NextlngCount ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-4-blog.excelhome.net EndWith EndSub 示例说明:本示例显示“打开文件”对话框,当用户在其中选择一个或多个文件后,将依次 显示每个文件的路径。其中,FileDialog属性返回打开和保存对话框中一系列对象的集合, 您可以对该集合对象的属性进行进一步的设置,如上例中的AllowMultiSelect属性设置为 True将允许用户选择多个文件。 示例01-12:保存Excel的工作环境 Sub保存Excel的工作环境() MsgBox"将Excel的工作环境保存到D:\ExcelSample\中" Application.SaveWorkspace"D:\ExcelSample\Sample" EndSub 示例说明:运行本程序后,将工作簿以带后缀名.xlw保存到D盘的ExcelSample文件夹中, 生成的文件全名为Sample.xlw。当改变工作簿并保存时,Excel会询问是覆盖原文件还是 保存副本。 示例01-13:改变Excel工作簿名字(Caption属性) SubSetCaption() Application.Caption="MyExcelBook" EndSub 示例说明:运行本程序后,将工作簿左上角Excel图标右侧的“MicrosoftExcel”改为“My ExcelBook”。 示例01-14:使用InputBox方法 SubSampleInputBox() DimvInput vInput=InputBox("请输入用户名:","获取用户名",Application.UserName) MsgBox"您好!"&vInput&".很高兴能认识您.",vbOKOnly,"打招呼" EndSub 示例01-15:设置页边距(CentimetersToPoints方法) SubSetLeftMargin() MsgBox"将工作表Sheet1的左页边距设为5厘米" Worksheets("Sheet1").PageSetup.LeftMargin=Application.CentimetersToPoints(5) EndSub 示例01-16:使用Windows的计算器(ActivateMicrosoftApp方法) SubCallCalculate() Application.ActivateMicrosoftAppIndex:=0 EndSub 示例说明:运行本程序后,将调用Windows的计算器。 示例01-17:在程序中运行另一个宏(Run方法) SubrunOtherMacro() ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-5-blog.excelhome.net MsgBox"本程序先选择A1至C6单元格区域后执行DrawLine宏" ActiveSheet.Range("A2:C6").Select Application.Run"DrawLine" EndSub 示例01-18:在指定的时间执行宏(OnTime方法) SubAfterTimetoRun() MsgBox"从现在开始,10秒后执行程序「testFullScreen」" Application.OnTimeNow+TimeValue("00:00:10"),"testFullScreen" EndSub 示例说明:运行本程序后,在10秒后将执行程序testFullScreen。 示例01-19:暂时停止宏运行(Wait方法) SubStop5sMacroRun() DimSetTimeAsDate MsgBox"按下「确定」,5秒后执行程序「testFullScreen」" SetTime=DateAdd("s",5,Now()) Application.WaitSetTime CalltestFullScreen EndSub 示例说明:运行本程序后,按下弹出的提示框中的“确定”按钮,等待5秒后执行另一程 序testFullScreen。 示例01-20:按下指定的按键后执行程序(OnKey方法) [示例01-20-1] SubPressKeytoRun() MsgBox"按下Ctrl+D后将执行程序「testFullScreen」" Application.OnKey"^{d}","testFullScreen" EndSub [示例01-20-2] SubResetKey() MsgBox"恢复原来的按键状态" Application.OnKey"^{d}" EndSub 示例说明:Onkey方法的作用主要是指定特定的键,当按下指定的键时运行相应的宏程序, 或者按下指定的键时,使Excel屏蔽特定的功能。 示例01-21:重新计算工作簿 [示例01-21-1] SubCalculateAllWorkbook() Application.Calculate EndSub 示例说明:当工作簿的计算模式被设置为手动模式后,运用Calculate方法可以重新计算所 有打开的工作簿、工作簿中特定的工作表或者工作表中指定的单元格区域。 ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-6-blog.excelhome.net [示例01-21-2] SubCalculateFullSample() IfApplication.CalculationVersion<>Workbooks(1).CalculationVersionThen Application.CalculateFull EndIf EndSub 示例说明:本示例先将当前MicrosoftExcel的版本与上次计算该工作簿的Excel版本进行 比较,如果两个版本不同,则对所有打开工作簿中的数据进行一次完整计算。其中, CalculationVersion属性返回工作簿的版本信息。 示例01-22:控制函数重新计算(Volatile方法) FunctionNonStaticRand() '当工作表中任意单元格重新计算时本函数更新 Application.VolatileTrue NonStaticRand=Rnd() EndFunction 示例说明:本示例摸仿Excel中的Rand()函数,当工作表单元格发生变化时,都会重新计 算该函数。在例子中,使用了Volatile方法,强制函数进行重新计算,即无论何时重新计算 工作表,该函数都会重新计算。 示例01-23:利用工作表函数(WorksheetFunction属性) SubWorksheetFunctionSample() DimmyRangeAsRange,answer SetmyRange=Worksheets("Sheet1").Range("A1:C10") answer=Application.WorksheetFunction.Min(myRange) MsgBoxanswer EndSub 示例说明:本示例获取工作表Sheet1中单元格区域A1:C10中的最小值,使用了工作表函 数Min()。一般,使用WorksheetFunction属性引用工作表函数,但如果VBA自带有实现 相同功能的函数,则直接使用该函数,否则会出现错误。 示例01-24:获取重叠区域(Intersect方法) SubIntersectRange() DimrSectAsRange Worksheets("Sheet1").Activate SetrSect=Application.Intersect(Range("rg1"),Range("rg2")) IfrSectIsNothingThen MsgBox"没有交叉区域" Else rSect.Select EndIf EndSub 示例说明:本示例在工作表Sheet1中选定两个命名区域rg1和rg2的重叠区域,如果所选 区域不重叠,则显示一条相应的信息。其中,Intersect方法返回一个Range对象,代表两 ExcelVBA>>ExcelVBA编程入门范例>>第一章Application对象(fanjy) 2006年9月9日http://fanjy.-7-blog.excelhome.net 个或多个范围重叠的矩形区域。 示例01-25:获取路径分隔符(PathSeparator属性) SubGetPathSeparator() MsgBox"路径分隔符为"&Application.PathSeparator EndSub 示例说明:本示例使用PathSeparator属性返回路径分隔符(“\”)。 示例01-26:快速移至指定位置(Goto方法) SubGotoSample() Application.GotoReference:=Worksheets("Sheet1").Range("A154"),_ scroll:=True EndSub 示例说明:本示例运行后,将当前单元格移至工作表Sheet1中的单元格A154。 示例01-27:显示内置对话框(Dialogs属性) SubDialogSample() Application.Dialogs(xlDialogOpen).Show EndSub 示例说明:本示例显示Excel的“打开”文件对话框。其中,Dialogs属性返回的集合代表 所有的Excel内置对话框。 示例01-28:退出Excel(SendKeys方法) SubSendKeysSample() Application.SendKeys("%fx") EndSub 示例说明:本示例使用SendKeys方法退出Excel,若未保存,则会弹出提示对话框并让用 户作出相应的选择。SendKeys方法的作用是摸拟键盘输入,如例中的“%fx”表示在Excel 中同时按下Alt、F和X三个键。 示例01-29:关闭Excel Sub关闭Excel() MsgBox"Excel将会关闭" Application.Quit EndSub 示例说明:运行本程序后,若该工作簿未保存,则会弹出对话框询问是否保存。 ============================= ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作 2006年9月23日http://fanjy.-1-blog.excelhome.net 第二章窗口(Window对象)基本操作应用示例 Window对象代表一个窗口,约有48个属性和14个方法,能对窗口特性进行设置和操作。 Window对象是Windows集合中的成员,对于Application对象来说,Windows集合包含 该应用程序中的所有窗口;对于Workbook对象来说,Windows集合只包含指定工作簿中 的窗口。下面介绍一些示例,以演示和说明Window对象及其属性和方法的运用。 示例02-01:激活窗口(Activate方法) SubSelectWindow() DimiWinAsLong,iAsLong,bWin MsgBox"依次切换已打开的窗口" iWin=Windows.Count MsgBox“您已打开的窗口数量为:”&iWin Fori=1ToiWin Windows(i).Activate bWin=MsgBox("您激活了第"&i&"个窗口,还要继续吗?",vbYesNo) IfbWin=vbNoThenExitSub Nexti EndSub 示例02-02:窗口状态(WindowState属性) [示例02-02-01] SubWindowStateTest() MsgBox"当前活动工作簿窗口将最小化" Windows(1).WindowState=xlMinimized MsgBox"当前活动工作簿窗口将恢复正常" Windows(1).WindowState=xlNormal MsgBox"当前活动工作簿窗口将最大化" Windows(1).WindowState=xlMaximized EndSub 示例说明:使用WindowState属性可以返回或者设置窗口的状态。示例中,常量xlMinimized、 xlNormal和xlMaximized分别代表窗口不同状态值,Windows(1)表示当前活动窗口。可以 使用Windows(index)来返回单个的Window对象,其中的index为窗口的名称或编号,活 动窗口总是Windows(1)。 [示例02-02-02] SubtestWindow() '测试Excel应用程序窗口状态 MsgBox"应用程序窗口将最大化" Application.WindowState=xlMaximized CalltestWindowState MsgBox"应用程序窗口将恢复正常" PDF文件使用"pdfFactoryPro"试用版本创建www.fineprint.cn ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作 2006年9月23日http://fanjy.-2-blog.excelhome.net Application.WindowState=xlNormal MsgBox"应用程序窗口已恢复正常" '测试活动工作簿窗口状态 MsgBox"当前活动工作簿窗口将最小化" ActiveWindow.WindowState=xlMinimized CalltestWindowState MsgBox"当前活动工作簿窗口将最大化" ActiveWindow.WindowState=xlMaximized CalltestWindowState MsgBox"当前活动工作簿窗口将恢复正常" ActiveWindow.WindowState=xlNormal CalltestWindowState MsgBox"应用程序窗口将最小化" Application.WindowState=xlMinimized CalltestWindowState EndSub ‘********************************************************* SubtestWindowState() SelectCaseApplication.WindowState CasexlMaximized:MsgBox"应用程序窗口已最大化" CasexlMinimized:MsgBox"应用程序窗口已最小化" CasexlNormal: SelectCaseActiveWindow.WindowState CasexlMaximized:MsgBox"当前活动工作簿窗口已最大化" CasexlMinimized:MsgBox"当前活动工作簿窗口已最小化" CasexlNormal:MsgBox"当前活动工作簿窗口已恢复正常" EndSelect EndSelect EndSub 示例说明:本示例有两个程序,其中testWindow()是主程序,调用子程序textWindowState(), 演示了应用程序窗口和工作簿窗口的不同状态。当前活动窗口一般代表当前活动工作簿窗 口,读者可以在VBE编辑器中按F8键逐语句运行testWindow()程序,观察Excel应用程 序及工作簿窗口的不同状态。此外,在子程序中,还运用了嵌套的SelectCase结构。 [示例02-02-03] SubSheetGradualGrow() DimxAsInteger WithActiveWindow .WindowState=xlNormal .Top=1 .Left=1 .Height=50 .Width=50 Forx=50ToApplication.UsableHeight ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作 2006年9月23日http://fanjy.-3-blog.excelhome.net .Height=x Nextx Forx=50ToApplication.UsableWidth .Width=x Nextx .WindowState=xlMaximized EndWith EndSub 示例说明:本示例将动态演示工作簿窗口由小到大直至最大化的变化过程。在运行程序时, 您可以将VBE窗口缩小,从而在工作簿中查看动态效果,也可以在Excel中选择菜单中的 宏命令执行以查看效果。 示例02-03:切换显示工作表元素 [示例02-03-01] SubtestDisplayHeading() MsgBox“切换显示/隐藏行列标号” ActiveWindow.DisplayHeadings=NotActiveWindow.DisplayHeadings EndSub 示例说明:本示例切换是否显示工作表中的行列标号。运行后,工作表中的行标号和列标号 将消失;再次运行后,行列标号重新出现,如此反复。您也可以将该属性设置为False,以 取消行列标号的显示,如ActiveWindow.DisplayHeadings=False;而将该属性设置为True, 则显示行列标号。 [示例02-03-02] SubtestDisplayGridline() MsgBox“切换显示/隐藏网格线” ActiveWindow.DisplayGridlines=NotActiveWindow.DisplayGridlines EndSub 示例说明:本示例切换是否显示工作表中的网格线。运行后,工作表中的网格线消失,再次 运行后,网格线重新出现,如此反复。您也可以将该属性设置为False,以取消网格线显示, 如ActiveWindow.DisplayGridlines=False;而将该属性设置为True,则显示网格线。 [示例02-03-03] SubDisplayHorizontalScrollBar() MsgBox“切换显示/隐藏水平滚动条” ActiveWindow.DisplayHorizontalScrollBar=_ NotActiveWindow.DisplayHorizontalScrollBar EndSub 示例说明:本示例切换是否显示工作表中的水平滚动条。运行后,工作表中的水平滚动条消 失,再次运行后,水平滚动条重新出现,如此反复。您也可以将该属性设置为False,以取 消水平滚动条,如ActiveWindow.DisplayHorizontalScrollBar=False;而将该属性设置为 ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作 2006年9月23日http://fanjy.-4-blog.excelhome.net True,则显示水平滚动条。 同理,DisplayVerticalScrollBar属性将用来设置垂直滚动条。 [示例02-03-04] SubDisplayScrollBar() MsgBox"切换显示/隐藏水平和垂直滚动条" Application.DisplayScrollBars=Not(Application.DisplayScrollBars) EndSub 示例说明:本示例切换是否显示工作表中的水平和垂直滚动条。运行后,工作表中的水平和 垂直滚动条同时消失,再次运行后,水平和垂直滚动条重新出现,如此反复。您也可以将该 属性设置为False,以取消水平和垂直滚动条显示,如Application.DisplayScrollBars=False; 而将该属性设置为True,则显示水平和垂直滚动条。 示例02-04:显示公式(DisplayFormulas属性) SubDisplayFormula() MsgBox“显示工作表中包含公式的单元格中的公式” ActiveWindow.DisplayFormulas=True EndSub 示例说明:本程序运行后,工作表中含有公式的单元格将显示公式而不是数值。若要显示数 值,则将该属性设置为False,或者,如果工作表中的公式显示的是结果数值,则该属性为 False。 示例02-05:显示/隐藏工作表标签(DisplayWorkbookTabs属性) SubtestDisplayWorkbookTab() MsgBox“隐藏工作表标签” ActiveWindow.DisplayWorkbookTabs=False EndSub 示例说明:本程序运行后,工作表标签消失。将该属性设置为True,重新显示工作表标签。 示例02-06:命名活动窗口(Caption属性) SubtestCaption() MsgBox"当前活动工作簿窗口的名字是:"&ActiveWindow.Caption ActiveWorkbook.Windows(1).Caption="我的工作簿" MsgBox"当前活动工作簿窗口的名字是:"&ActiveWindow.Caption EndSub 示例说明:本程序运行后,显示当前活动工作簿窗口原先的名称(即工作簿窗口未处于最大 化状态时,出现在窗口顶部标题栏中的文字),然后设置当前活动工作簿窗口名称,即使用 语句ActiveWorkbook.Windows(1).Caption="我的工作簿",最后显示当前活动工作簿窗口 的新名称。改变窗口的标题并不会改变工作簿的名称。 示例02-07:移动窗口到指定位置(ScrollRow属性和ScrollColumn属性) ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作 2006年9月23日http://fanjy.-5-blog.excelhome.net SubtestScroll() MsgBox“将当前窗口工作表左上角单元格移至第10行第3列” ActiveWindow.ScrollRow=10 ActiveWindow.ScrollColumn=3 EndSub 示例说明:本程序运行后,当前活动窗口左上角单元格为第10行第3列。可以通过设置这 两个属性来移动窗口到指定的位置,也可以返回指定窗格或窗口最左上面的行号或列号。 示例02-08:调整窗口(EnableResize属性) SubtestResize() MsgBo
本文档为【Excel VBA编程入门范例】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: ¥18.0 已有0 人下载
最新资料
资料动态
专题动态
个人认证用户
万里长城
一线小学教师
格式:xls
大小:175KB
软件:Excel
页数:0
分类:互联网
上传时间:2019-03-25
浏览量:24