您好,欢迎访问三七文档
当前位置:首页 > 机械/制造/汽车 > 制造加工工艺 > 150个ExcelVBA编程实例
1第一章Excel应用程序对象(Application对象)及其常用方法基本操作应用示例分类:ExcelVBAExcelVBA编程入门范例Application对象代表整个MicrosoftExcel应用程序,带有175个属性和52个方法,可以设置整个应用程序的环境或配置应用程序。示例01-01:体验开/关屏幕更新(ScreenUpdating属性)Sub关闭屏幕更新()MsgBox顺序切换工作表Sheet1→Sheet2→Sheet3→Sheet2,先开启屏幕更新,然后关闭屏幕更新Worksheets(1).SelectMsgBox目前屏幕中显示工作表Sheet1Application.ScreenUpdating=TrueWorksheets(2).SelectMsgBox显示Sheet2了吗?Worksheets(3).SelectMsgBox显示Sheet3了吗?Worksheets(2).SelectMsgBox下面与前面执行的程序代码相同,但关闭屏幕更新功能Worksheets(1).SelectMsgBox目前屏幕中显示工作表Sheet1&Chr(10)&关屏屏幕更新功能Application.ScreenUpdating=FalseWorksheets(2).SelectMsgBox显示Sheet2了吗?Worksheets(3).SelectMsgBox显示Sheet3了吗?Worksheets(2).SelectApplication.ScreenUpdating=TrueEndSub示例说明:ScreenUpdating属性用来控制屏幕更新。当运行一个宏程序处理涉及到多个工作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CPU的处理时间,从而降低程序的运行速度,而关闭该属性则可显著提高程序运行速度。示例01-02:使用状态栏(StatusBar属性)SubtestStatusBar()Application.DisplayStatusBar=True'开启状态栏显示'赋值状态栏显示的文本2Application.StatusBar=示例说明:StatusBar属性用来指定显示在状态栏上的信息。若不想再显示状态栏文本,可使用Application.StatusBar=False语句关闭状态栏显示,也可以在程序开始将原先的状态栏设置存储,如使用语句oldStatusBar=Application.DisplayStatusBar将状态栏原来的信息存储在变量oldStatusBar,在程序运行完成或退出时,将变量重新赋值给状态栏,如使用语句Application.DisplayStatusBar=oldStatusBar,以恢复状态栏原状。示例01-03:处理光标(Cursor属性)SubViewCursors()Application.Cursor=xlNorthwestArrowMsgBox您将使用箭头光标,切换到Excel界面查看光标形状Application.Cursor=xlIBeamMsgBox您将使用工形光标,切换到Excel界面查看光标形状Application.Cursor=xlWaitMsgBox您将使用等待形光标,切换到Excel界面查看光标形状Application.Cursor=xlDefaultMsgBox您已将光标恢复为缺省状态EndSub示例01-04:获取系统信息SubGetSystemInfo()MsgBoxExcel版本信息为:&Application.CalculationVersionMsgBoxExcel当前允许使用的内存为:&Application.MemoryFreeMsgBoxExcel当前已使用的内存为:&Application.MemoryUsedMsgBoxExcel可以使用的内存为:&Application.MemoryTotalMsgBox本机操作系统的名称和版本为:&Application.OperatingSystemMsgBox本产品所登记的组织名为:&Application.OrganizationNameMsgBox当前用户名为:&Application.UserNameMsgBox当前使用的Excel版本为:&Application.VersionEndSub示例说明:可以使用给UserName属性赋值以设置用户名称。示例01-05:退出复制/剪切模式(CutCopyMode属性)SubexitCutCopyMode()Application.CutCopyMode=FalseEndSub示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会在原单元格区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用Application.CutCopyMode=False语句恢复该属性的默认设置。示例01-06:禁止弹出警告信息(DisplayAlerts属性)SubtestAlertsDisplay()3Application.DisplayAlerts=FalseEndSub示例说明:在程序运行过程中,有时由于Excel本身设置的原因,会弹出对话框,从而中断程序的运行,您可以在程序之前加上Application.DisplayAlerts=False语句以禁止弹出这些对话框而不影响程序正常运行。需要注意的是,在程序运行结束前,应使DisplayAlerts属性恢复为缺省状态,即使用语句Application.DisplayAlerts=True。该属性的默认设置为True,当将该属性设置为False时,Excel会使直接使用对话框中默认的选择,从而不会因为弹出对话框而影响程序运行。示例01-07:将Excel全屏幕显示SubtestFullScreen()MsgBox运行后将Excel的显示模式设置为全屏幕Application.DisplayFullScreen=TrueMsgBox恢复为原来的状态Application.DisplayFullScreen=FalseEndSub示例01-08:Excel启动的文件夹路径SubExcelStartfolder()MsgBoxExcel启动的文件夹路径为:&Chr(10)&Application.StartupPathEndSub示例01-09:打开最近使用过的文档SubOpenRecentFiles()MsgBox显示最近使用过的第三个文件名,并打开该文件MsgBox最近使用的第三个文件的名称为:&Application.RecentFiles(3).NameApplication.RecentFiles(3).OpenEndSub示例01-10:打开文件(FindFile方法)SubFindFileOpen()OnErrorResumeNextMsgBox请打开文件,vbOKOnly+vbInformation,打开文件IfNotApplication.FindFileThenMsgBox文件未找到,vbOKOnly+vbInformation,打开失败EndIfEndSub示例说明:本示例将显示“打开”文件对话框,若用户未打开文件(即点击“取消”按钮),则会显示“打开失败”信息框。示例中使用了FindFile方法,用来显示“打开”对话框并让用户打开一个文件。如果成功打开一个新文件,则该值为True。如果用户取消了操作并退出该对话框,则该值为False。4示例01-11:文件对话框操作(FileDialog属性)SubUseFileDialogOpen()DimlngCountAsLong'开启打开文件对话框WithApplication.FileDialog(msoFileDialogOpen).AllowMultiSelect=True.Show'显示所选的每个文件的路径ForlngCount=1To.SelectedItems.CountMsgBox.SelectedItems(lngCount)NextlngCountEndWithEndSub示例说明:本示例显示“打开文件”对话框,当用户在其中选择一个或多个文件后,将依次显示每个文件的路径。其中,FileDialog属性返回打开和保存对话框中一系列对象的集合,您可以对该集合对象的属性进行进一步的设置,如上例中的AllowMultiSelect属性设置为True将允许用户选择多个文件。示例01-12:保存Excel的工作环境Sub保存Excel的工作环境()MsgBox将Excel的工作环境保存到D:\ExcelSample\中Application.SaveWorkspaceD:\ExcelSample\SampleEndSub示例说明:运行本程序后,将工作簿以带后缀名.xlw保存到D盘的ExcelSample文件夹中,生成的文件全名为Sample.xlw。当改变工作簿并保存时,Excel会询问是覆盖原文件还是保存副本。示例01-13:改变Excel工作簿名字(Caption属性)SubSetCaption()Application.Caption=MyExcelBookEndSub示例说明:运行本程序后,将工作簿左上角Excel图标右侧的“MicrosoftExcel”改为“MyExcelBook”。示例01-14:使用InputBox方法SubSampleInputBox()DimvInputvInput=InputBox(请输入用户名:,获取用户名,Application.UserName)MsgBox您好!&vInput&.很高兴能认识您.,vbOKOnly,打招呼EndSub示例01-15:设置页边距(CentimetersToPoints方法)SubSetLeftMargin()MsgBox将工作表Sheet1的左页边距设为5厘米5Worksheets(Sheet1).PageSetup.LeftMargin=Application.CentimetersToPoints(5)EndSub示例01-16:使用Windows的计算器(ActivateMicrosoftApp方法)SubCallCalculate()Application.ActivateMicrosoftAppIndex:=0EndSub示例说明:运行本程序后,将调用Windows的计算器。示例01-17:在程序中运行另一个宏(Run方法)SubrunOtherMacro()MsgBox本程序先选择A1至C6单元格区域后执行DrawLine宏ActiveSheet.Range(A2:C6).SelectApplication.RunDrawLineEndSub示例01-18:在指定的时间执行宏(OnTime方法)SubAfterTimetoRun()MsgBox从现在开始,10秒后执行程序「testFullScreen」Application.OnTimeNow+TimeValue(00:00:10),testFullScreenEndSub示例说明:运行本程序后,在10秒后将执行程序testFullScreen。示例01-19:暂时停止宏运行(Wait方法)SubStop5sMacroRun()DimSetTimeAsDateMsgBox按下「确定」,5秒后执行程序「testFullScreen」SetTime=DateAdd(s,5,Now())Application.WaitSetTimeCalltestFullScreenEndSub示例说明:运行本程序后,按下弹出的提示框中的“确定”按钮,等待5秒后执行另一程序testFullScreen。示例01-20:按下指定的按键后执行程序(OnKey方法)[示例01-20-1]SubPressKeytoRun()MsgBox按下Ctrl+D后将执行程序「testFullScreen」A
本文标题:150个ExcelVBA编程实例
链接地址:https://www.777doc.com/doc-1330506 .html