靠谱电子书 > 经管其他电子书 > excel_vba_编程教程(完整版) >

第71部分

excel_vba_编程教程(完整版)-第71部分

小说: excel_vba_编程教程(完整版) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!



              End With   
              ntrols。Add(Type:=msoControlButton)。Caption = 〃Free Memory〃   
              With ntrols(〃Free Memory〃)   
                   。FaceId = 2153   
                   。OnAction = 〃FreeMemory〃   
              End With   
         End With   
     End Sub   
     上面的过程创建了一个名为Information的自定义快捷菜单,并给它添加了四个命令。注意, 
     每个命令都指定了一个图标。当你从该快捷菜单选择一命令,步骤2里面的相应过程就会被执 
     行。  
2。  输入下面为Create_ShortMenu过程调用的过程:  
     Sub FreeMemory( )   
         MsgBox Application。MemoryFree & 〃 bytes〃; ; 〃Free Memory〃   
     End Sub   
     Sub OpSystem( )   
         MsgBox Application。OperatingSystem; ; 〃Operating System〃   
     End Sub   
     Sub TotalMemory( )   
         MsgBox Application。MemoryTotal; ; 〃Total Memory〃   
     End Sub   
     Sub UsedMemory( )   
         MsgBox Application。MemoryUsed; ; 〃Used Memory〃   
     End Sub   
     要将名为Information的自定义快捷键显示在屏幕上的话,你可以使用方法ShowPopup,如步 
骤3所示。  
3。  在立即窗口里输入下述语句:  
    mandBars(〃Information〃)。ShowPopup 0; 0   
    对象mandBar的方法ShowPopup接受两个可选参数(x; y),决定快捷菜单在屏幕上的位置。 
    在上面的例子里,快捷菜单Information将出现在屏幕的左上角。  

                                         247 

… 页面 264…

假设你正在设计一个自定义窗体,并想要当用户右键单击一个命令按钮时显示一个快捷菜单:  
1。  从VB编辑器菜单上,选择插入…用户窗体  
2。  使用工具箱上的命令控件,在空白用户窗体的任意位置放置一个按钮  
3。  通过点击工程浏览器窗口的查看代码按钮,切换到该窗体的代码窗口  
4。  在UserForm1代码窗口里输入下述过程:  
     Private Sub mandButton1_MouseDown(ByVal Button _   
       As Integer; _   
       ByVal Shift As Integer; _   
       ByVal X As Single; _   
       ByVal Y As Single)   
         If Button = 2 Then   
         Call Show_ShortMenu   
         Else   
         MsgBox 〃You must right…click this button。〃   
         End If   
     End Sub   
当用户右键点击窗体上按钮时,该过程就会调用过程Show_ShortMenu。点击鼠标按钮时VB会有两个 
事件过程响应。当你点击鼠标按钮时,VB会执行MouseDown事件过程,当你释放鼠标按键,MouseUp 
事件则会发生。  
MouseDown和MouseUp事件过程要求下述参数:  
*  参数object确定对象,在该例中,是窗体上面的命令按钮名称  
*  参数Button是整型数据,确定按下的是哪个鼠标按键  
     Button参数值            意义  
     1                       鼠标左键  
     2                       鼠标右键  
     3                       鼠标中键  
*  参数Shift确定当事件发生时,用户是否按住了Shift; Crel或者Alt键。  
     Shift参数值             意义  
     1                       Shift键  
     2                       Ctrl键  
     3                       Shift和Ctrl键  
     4                       Alt键  
     5                       Alt和Shift键  
     6                       Alt和Ctrl键  
     7                       Alt; Shift和Ctrl键  
5。  在当前工程模块里输入过程Show_ShortMenu代码:  
     Sub Show_ShortMenu()   
         Dim shortMenu As Object   
         Set shortMenu = ApplicationmandBars(〃Information〃)   
         With shortMenu   
               。ShowPopup   
         End With   
     End Sub   
     注意,本过程使用的方法ShowPopup没有使用决定快捷菜单屏幕显示位置的可选参数,因此, 
     菜单将出现在鼠标点击的位置(见图12…11)。  
6。  要删除名为Information的快捷菜单的话,请在代码窗口输入并且运行下述过程 
    Delete_ShortMenu:  
     Sub Delete_ShortMenu()   
         ApplicationmandBars(〃Information〃)。Delete   
     End Sub   

                                          248 

… 页面 265…

                                                  
图12…11 当你右键点击一个对象时出现的自定义快捷菜单  

13。接下来……  

在本章,你学习了如何使用VBA修改内置菜单和工具栏,如何创建和显示你自己的工具栏,菜单和 
快捷菜单。当使用菜单和工具栏时,你使用了对象mandBar的各种属性和方法。你学习了三种类 
型的对象mandBar:Normal,MenuBar和Popup。使用立即窗口,你试验了示范如何创建自己的工 
具栏和控件。  
下一章将带你进入错误捕捉和调试,换句话说,你将学习当你的程序工作不正确时,该做些什么。  

                             第十三章 调试 VBA 过程和处理错误   

错误要悄悄混入你的VBA过程很容易,事实是,无论你多么仔细,你所有的VBA过程第一次就能全部 
运行正确,这是极其少见的事。总有一些事情你错过了或者没有想到过。从第二章起,你就知道有 
三种类型的VBA错误:语法错误,逻辑错误和运行时间错误。本章将给介绍许多内置工具,你会发 
现它们在你的过程代码的分析和定位错误源的过程中是很有用的。  

1。测试 VBA 过程  

迄今为止,在本书中,你已经创建和执行了很多过程和函数例子。因为这些程序中的大多数都很短, 
所以找错误并不是非常困难。然而,当你编写更长更复杂的过程时,查找错误源就更缓慢和费时了。 
幸运的是,VBA编辑器提供了一套方便的工具,让你追踪你VBA问题的过程更简单,更快捷,有更少 
的挫折。程序缺陷是电脑程序中的错误,而调试则是定位和解决这些错误的过程。调试让你找到你 
的程序为什么不按预期工作的原因。你可以通过步入程序代码或者检查变量值来达到目的。  
使用下述指南进行你的VBA程序调试:  
*  如果你想要分析你的过程,通过按F8或者选择调试…逐语句,逐语句地执行你的代码  
*  如果你怀疑程序的某个地方有错误发生,那么可以使用断点  
*  如果你想监测程序中某个变量或者表达式的值,那么可以添加一个监视表达式  
*  如果你讨厌在冗长的程序代码中拉动滚动条到你感兴趣的部分去,那么你可以设置一个书签, 
      快速跳到需要的地方。  
每条指南在本章中都有实用的例子进行示范。  

2。终止过程  

你知道如何终止VB过程吗?如果你想到了按Esc键,那么你对了。如果你在运行程序,并且突然按 
下Esc键,那么VB就会中断程序的运行,并显示如图13…1显示的信息。然而除了Esc键,这个在很多 
情况下都很有力而且可靠的方法,VBA还提供了很多其它的方法来中断你的过程,进入所谓的中断 
模式:  
*  按Ctrl+Break  
*  设置一个或多个断点  
*  插入Stop语句  
*  添加监视表达式  
当你的程序执行被临时停止时,断点便发生了。VB会从过程的执行中记住所有变量和语句的值,当 
用户从工具栏点击运行宏(或者“运行”菜单上的相同名称),或者点击对话框(图13…1)上面的 
继续按钮,可以恢复。  

                                           249 

… 页面 266…

                                                        
图13…1 在你运行程序时,如果你按下Esc键或者Ctrl+Break键,就会出现该信息  
图13…1显示的错误对话框通知你该过程已被中断,下述按钮可用:  
                    
继续              点击该按钮可以恢复代码执行。如果遇到错误该按钮将变灰  
结束              如果你这次不想排除故障则点击该按钮,VBA将终止代码执行  
调试              点击该按钮进入中断模式。代码窗口将出现,并且VBA会加亮过程执行时停止 
                  处的代码行。你可以检查,调试,中断或者逐句执行代码。注意,当VBA工程 
                  被保护时,该按钮变灰  
帮助              点击该按钮查看在线帮助,解释该错误信息的导致原因  
  
技巧13…1 防止用户干预  
通过将下述语句加入到过程代码中去,你可以防止用户中断你的程序:  
Application。EnableCancelKey = xlDisabled  
当用户在程序运行时按下Esc或者Ctrl+Break时,不会发生任何情况。应用程序对象的属性 
EnableCancelKey禁用了这些键。  

3。使用断点  

如果你多少知道点你程序代码有问题,那么你应该在那里(给定的行)暂停代码执行。要设置断点, 
简单点就是当光标位于目标代码行时按下F9。当过程运行中VBA到达此处时,立即会显示代码窗口。 
这时,你可以通过按F8或者选择调试…逐语句来一行一行地运行代码。  
我们来看看下面一个方案,看看它是如何工作的。假设在过程ChangeCode的执行中下面的代码行会 
出问题:  
ActiveCell。Formula = 〃=VLookup(RC'1';Codes。xls!R1C1:R6C2;2)〃   
1。  准备好如图13…2和13…3所示的电子表格。保存图13…2所示的数据为Chap13。xls,图13…3所示的 
    数据为Codes。xls。关闭文件Codes。xls。  

                                                                              
    图13…2 本文件中输入在D列的编号将会在过程ChangeCode中被显示于土13…3中的编号所代替  

                                          250 

… 页面 267…

2。 
      
    图13…3 过程ChangeCode使用该编号表作查找目的  
      
3。  激活文件Chap13。xls,切换到VB编辑器窗口  
4。  使用属性窗口重新命名VBAProject(Chap13。xls)为Debugging  
5。  插入模块到Debugging (Chap13。xls)工程,并且更改名Name属性为Breaks  
6。  输入过程代码ChangeCode,如下所示:  
     Sub ChangeCode()   
         Workbooks。Open FileName:=〃C:Codes。xls〃 ‘将此处文件路径改为你的真实路径  
         Windows(〃Chap13。xls〃)。Activate   
         Columns(〃D:D〃)。Select   
         Selection。Insert Shift:=xlToRight   
         Range(〃D1〃)。Select   
         ActiveCell。Formula = 〃Code〃   
         Columns(〃D:D〃)。Select   
         Selection。SpecialCells(xlBlanks)。Select   
         ActiveCell。Formula = 〃=VLookup(RC'1';Codes。xls!R1C1:R6C2;2)〃   
         Selection。FillDown   
         With Columns(〃D:D〃)   
              。EntireColumn。AutoFit   
              。Select   
         End With   
         Selectionpy   
         Selection。PasteSpecial Paste:=xlValues   
         Rows(〃1:1〃)。Select   
         With Selection   
              。HorizontalAlignment = xlCenter   
              。VerticalAlignment = xlBottom   
              。Orientation = xlHorizontal   
         End With   
         Workbooks(〃Codes。xls〃)。Close   
     End Sub   
7。  在过程ChangeCode里,点击下述语句行的任意地方:  
    ActiveCell。Formula = 〃=VLookup(RC'1';Codes。xls!R1C1:R6C2;2)〃   
8。  按下F9(或者选择调试…切换断点)来在光标所在处设置一个断点。设置断点的另外一种方法 
    是点击你要暂停程序的代码左边的页边

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的