说明:许多都是转别人的,希望和大家多交流,多学习,共同进步:)

VBA编程规则及方法技巧

上一篇 / 下一篇  2008-06-10 12:22:31 / 个人分类:转帖

查看( 137 ) / 评论( 2 )
1、在自定义函数前加上Private关键字进行声明,该函数将不会出现在Excel的“粘贴函数”对话框中,但仍然可以在公式中运用它们。如果是专门为其他的VBA过程开发的自定义函数,则应该使用Private关键字进行声明。MSCBSC | 移动通信网9WPp1K^3e Q
2、 通常,用户自定义函数后,在“粘贴函数”对话框中将会出现在“用户定义”类别中。如果希望自定义函数出现在其它的类别中,必须编写和执行VBA代码为自定 义函数指定类别。如运行Application.MacroOptions Macro:=”SumPro”,Category:=4语句后,将自定义的SumPro函数指定给“统计函数”类别。
EqH9VD_03、与Sub过程不同,自 定义函数Function过程并不出现在宏对话框中;当执行VBE编辑器中的“运行——运行子过程/用户窗体”命令时,如果光标位于某Function过 程中,就不能获取宏对话框并从中选择要运行的宏。因此,在开发过程的时候,必须采取其它方式对自定义函数进行测试,可以设置调用该函数的过程;如果该函数 是用在工作表公式中的,可以在工作表中输入简单的公式进行测试。MSCBSC | 移动通信网u!F9f1Xkm'H9_
4、如果在公式中使用了自定义函数,但返回值“VALUE!”,表明函数中有错误。错误的原因可能是代码中的逻辑错误、可能给函数传递了不正确的参数、可能执行了禁用的动作如试图更改单元格的格式。MSCBSC | 移动通信网h;F4Z S d
5、在自定义函数中使用参数时,可选参数必须在任何必需的参数之后。在参数名称前加上关键字Optional即可指定一个可选的参数。
1~v8oo1A.`j$~0如果必须确定某可选的参数是否传递给了某函数,应将该参数声明为Variant类型,然后在过程代码中使用IsMissing函数来进行判断。
p;J{&e+XWF0要创建包含不定数量参数的自定义函数,使用一个数组作为最后一个(或惟一的)参数,并在数组前面加上关键字ParamArray。关键字ParamArray只能用于参数列表中的最后一个参数,其数据类型总是Variant并且是一个可选的参数。
5g!Z${N6F06、在自定义函数的程序代码中,应确保至少有一次把合适的值赋给了函数的名称。
\>a)C&` LJk P(m07、函数的名称必须遵循一定的规则(与变量名称相同)。最好不要采取与单元格地址相同的形式,并且还要避免使用与Excel内置函数名称相同的名称,否则,Excel会使用内置函数。
yM-[4W1l,NDF08、如果想将Case关键字和相应的语句放在同一行上,在Case语名与相应语句间加上分隔符冒号(MSCBSC | 移动通信网-aSaQC*g%EBo2?
9、通常情况下,VBA中对文本进行比较等操作是区分大小写的,若将语句Option Compare Text添加到模块的顶部,则程序执行时不会区分大小写。
s T+{'B/AA:Qv K010、要处理单元格区域,在代码中不必先选项中该单元格区域。MSCBSC | 移动通信网5TFNl)^
MSCBSC | 移动通信网 WtU6D,j

7c/`5~pqv01、编写自定义函数时,必须在VBA模块中,而不是在与ThisWorkbook、工作表和用户窗体关联的代码模块中。MSCBSC | 移动通信网2U5e:O4}3zd-p$]L
2、如果代码要选中单元格区域,则该区域所在的工作表必须是活动的,可以使用Activate方法来激活某工作表。MSCBSC | 移动通信网*[.H k}mh;t
3、尽量在VBA代码中使用命名的单元格区域。MSCBSC | 移动通信网2XdcVvCAcI
4、当通过快捷键选择单元格区域的时候,如果用宏录制器生成代码,则要认真检查代码中是否有对选中的实际单元格录制硬编码的引用。MSCBSC | 移动通信网X0J,g3jY[zI ?v
5、如果某个宏应用于当前单元格区域中的每个单元格,但用户可能会选中整行或整列,通常,我们不需要遍历选区中的每个单元格,那么这个宏应创建一个子选区,使其只由非空单元格组成。
+[PfbTn$|n06、Excel允许同时有多个选区。MSCBSC | 移动通信网&J6v~9ax[k7Rp
7、若定义了单元格区域的名称,则在代码中使用定义的名称时,即使在名称单元格区域中添加或删除了行或列,也能确保正确使用该单元格区域。MSCBSC | 移动通信网%s kj&w PU
8、在VBA代码中使用注释,可以简要描述编写的每个过程的目的、对过程所做的任何修改、描述变量的目的等。
!E#Yb*e:qH.Q7] zT0通过使用VBE中“编辑”工具栏的“设置注释块/解除注释块”,也可以将VBA语句暂时设置成注释块,以便于调试。MSCBSC | 移动通信网C&Y+Kin*{&zK_
9、在工作表中编辑控件。在拖动控件的同时按Alt键,按钮将与工作表的网格线对齐;在拖动的同时按Shift键,按钮成正方形MSCBSC | 移动通信网1l:n6p7^ c6Mh0Q
10、通常,将Application对象的EnableEvents属性设置为False即可禁止事件发生。但要注意的是,这个属性只对真正的Excel对象(如Workbooks,Worksheets,Charts等)的事件产生作用。

TAG:

fse2006的个人空间 fse2006 发布于2008-06-17 11:51:50
Excellent
A8733574发布于2008-06-24 22:27:46
是原创的?不在于写得多好 重在动笔
我来说两句

(可选)

日历

« 2008-11-20  
      1
2345678
9101112131415
16171819202122
23242526272829
30      

数据统计

  • 访问量: 17126
  • 日志数: 79
  • 建立时间: 2008-05-10
  • 更新时间: 2008-11-15

RSS订阅

Open Toolbar