ExcelVBA编实战编程(很实用哦) 联系客服

发布时间 : 星期五 文章ExcelVBA编实战编程(很实用哦)更新完毕开始阅读1a1fe515ee06eff9aef807fe

(1)Excel 2003高级VBA编程宝典

(2)Excel 2003与VBA编程从入门到精通(中文版) (3)巧学巧用Excel 2003 VBA与宏(中文版) (4)ExcelVBA应用程序专业设计实用指南 (5)ExcelVBA应用开发与实例精讲 (6)一些网上资源

更多的信息

关于ExcelVBA的更多参考和学习资源,可以在www.excelhome.net上查找,有疑问也可以在ExcelHome论坛中提问。您也可以登录我的博客http://fanjy.blog.excelhome.net,上面有很多Excel的学习资料。同时,欢迎与我联系交流,我的e-mail是:xhdsxfjy@163.com。

“学习Excel,使用VBA对Excel进行控制操作是我很热衷的业余爱好之一。”——fanjy

第一章 Excel应用程序对象(Application对象)及其常用方法

基本操作应用示例 分类:ExcelVBA>>ExcelVBA编程入门范例 Application对象代表整个Microsoft Excel应用程序,带有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

9

Worksheets(2).Select

MsgBox \显示Sheet2了吗?\ Worksheets(3).Select

MsgBox \显示Sheet3了吗?\ Worksheets(2).Select

Application.ScreenUpdating = True End Sub

示例说明:ScreenUpdating属性用来控制屏幕更新。当运行一个宏程序处理涉及到多个工作表或单元格中的大量数据时,若没有关闭屏幕更新,则会占用CPU的处理时间,从而降低程序的运行速度,而关闭该属性则可显著提高程序运行速度。

示例01-02:使用状态栏(StatusBar属性) Sub testStatusBar()

Application.DisplayStatusBar = True '开启状态栏显示 '赋值状态栏显示的文本

Application.StatusBar = \End Sub

示例说明:StatusBar属性用来指定显示在状态栏上的信息。若不想再显示状态栏文本,可使用Application.StatusBar = False语句关闭状态栏显示,也可以在程序开始将原先的状态栏设置存储,如使用语句oldStatusBar = Application.DisplayStatusBar将状态栏原来的信息存储在变量oldStatusBar,在程序运行完成或退出时,将变量重新赋值给状态栏,如使用语句Application.DisplayStatusBar = oldStatusBar,以恢复状态栏原状。

示例01-03:处理光标(Cursor属性) Sub ViewCursors()

Application.Cursor = xlNorthwestArrow

MsgBox \您将使用箭头光标,切换到Excel界面查看光标形状\ Application.Cursor = xlIBeam

MsgBox \您将使用工形光标,切换到Excel界面查看光标形状\ Application.Cursor = xlWait

MsgBox \您将使用等待形光标,切换到Excel界面查看光标形状\ Application.Cursor = xlDefault

MsgBox \您已将光标恢复为缺省状态\End Sub

示例01-04:获取系统信息 Sub GetSystemInfo()

MsgBox \版本信息为:\& Application.CalculationVersion

MsgBox \当前允许使用的内存为:\& Application.MemoryFree MsgBox \当前已使用的内存为:\& Application.MemoryUsed MsgBox \可以使用的内存为:\& Application.MemoryTotal

MsgBox \本机操作系统的名称和版本为:\& Application.OperatingSystem

10

MsgBox \本产品所登记的组织名为:\& Application.OrganizationName MsgBox \当前用户名为:\& Application.UserName

MsgBox \当前使用的Excel版本为:\& Application.Version End Sub

示例说明:可以使用给UserName属性赋值以设置用户名称。

示例01-05:退出复制/剪切模式(CutCopyMode属性) Sub exitCutCopyMode()

Application.CutCopyMode = False End Sub

示例说明:退出复制/剪切模式后,在程序运行时所进行的复制或剪切操作不会在原单元格区域留下流动的虚框线。需要提醒的是,在程序运行完后,应使用Application.CutCopyMode = False语句恢复该属性的默认设置。

示例01-06:禁止弹出警告信息(DisplayAlerts属性) Sub testAlertsDisplay()

Application.DisplayAlerts = False End Sub 示例说明:在程序运行过程中,有时由于Excel本身设置的原因,会弹出对话框,从而中断程序的运行,您可以在程序之前加上Application.DisplayAlerts = False语句以禁止弹出这些对话框而不影响程序正常运行。需要注意的是,在程序运行结束前,应使DisplayAlerts属性恢复为缺省状态,即使用语句Application.DisplayAlerts = True。该属性的默认设置为True,当将该属性设置为False时,Excel会使直接使用对话框中默认的选择,从而不会因为弹出对话框而影响程序运行。

示例01-07:将Excel全屏幕显示 Sub testFullScreen()

MsgBox \运行后将Excel的显示模式设置为全屏幕\ Application.DisplayFullScreen = True MsgBox \恢复为原来的状态\

Application.DisplayFullScreen = False End Sub

示例01-08:Excel启动的文件夹路径 Sub ExcelStartfolder()

MsgBox \启动的文件夹路径为:\& Chr(10) & Application.StartupPath

End Sub

示例01-09:打开最近使用过的文档 Sub OpenRecentFiles()

MsgBox \显示最近使用过的第三个文件名,并打开该文件\

MsgBox \最近使用的第三个文件的名称为:\& Application.RecentFiles(3).Name

11

Application.RecentFiles(3).Open End Sub

示例01-10:打开文件(FindFile方法) Sub FindFileOpen()

On Error Resume Next

MsgBox \请打开文件\vbOKOnly + vbInformation, \打开文件\ If Not Application.FindFile Then

MsgBox \文件未找到\vbOKOnly + vbInformation, \打开失败\ End If End Sub

示例说明:本示例将显示“打开”文件对话框,若用户未打开文件(即点击“取消”按钮),则会显示“打开失败”信息框。示例中使用了FindFile方法,用来显示“打开”对话框并让用户打开一个文件。如果成功打开一个新文件,则该值为True。如果用户取消了操作并退出该对话框,则该值为False。

示例01-11:文件对话框操作(FileDialog属性) Sub UseFileDialogOpen() Dim lngCount As Long '开启\打开文件\对话框

With Application.FileDialog(msoFileDialogOpen) .AllowMultiSelect = True .Show

'显示所选的每个文件的路径

For lngCount = 1 To .SelectedItems.Count MsgBox .SelectedItems(lngCount) Next lngCount End With End Sub 示例说明:本示例显示“打开文件”对话框,当用户在其中选择一个或多个文件后,将依次显示每个文件的路径。其中,FileDialog属性返回打开和保存对话框中一系列对象的集合,您可以对该集合对象的属性进行进一步的设置,如上例中的AllowMultiSelect属性设置为True将允许用户选择多个文件。

示例01-12:保存Excel的工作环境 Sub 保存Excel的工作环境()

MsgBox \将Excel的工作环境保存到D:\\ExcelSample\\中\ Application.SaveWorkspace \End Sub

示例说明:运行本程序后,将工作簿以带后缀名.xlw保存到D盘的ExcelSample文件夹中,生成的文件全名为Sample.xlw。当改变工作簿并保存时,Excel会询问是覆盖原文件还是保存副本。

示例01-13:改变Excel工作簿名字(Caption属性)

12