1、在自定义函数前加上Private关键字进行声明,该函数将不会出现在Excel的“粘贴函数”对话框中,但仍然可以在公式中运用它们。如果是专门为其他的VBA过程开发的自定义函数,则应该使用Private关键字进行声明。
-{'O9wV"u`'^(i02、 通常,用户自定义函数后,在“粘贴函数”对话框中将会出现在“用户定义”类别中。如果希望自定义函数出现在其它的类别中,必须编写和执行VBA代码为自定 义函数指定类别。如运行Application.MacroOptions Macro:=”SumPro”,Category:=4语句后,将自定义的SumPro函数指定给“统计函数”类别。
"h\%I)f!t03、与Sub过程不同,自 定义函数Function过程并不出现在宏对话框中;当执行VBE编辑器中的“运行——运行子过程/用户窗体”命令时,如果光标位于某Function过 程中,就不能获取宏对话框并从中选择要运行的宏。因此,在开发过程的时候,必须采取其它方式对自定义函数进行测试,可以设置调用该函数的过程;如果该函数 是用在工作表公式中的,可以在工作表中输入简单的公式进行测试。
MSCBSC | 移动通信网U8G[/~gH:^Ar
~&bT4、如果在公式中使用了自定义函数,但返回值“VALUE!”,表明函数中有错误。错误的原因可能是代码中的逻辑错误、可能给函数传递了不正确的参数、可能执行了禁用的动作如试图更改单元格的格式。
8r4g!P.C@R05、在自定义函数中使用参数时,可选参数必须在任何必需的参数之后。在参数名称前加上关键字Optional即可指定一个可选的参数。
[i7|c2rl"`{0如果必须确定某可选的参数是否传递给了某函数,应将该参数声明为Variant类型,然后在过程代码中使用IsMissing函数来进行判断。
U
]8`X-JHS0要创建包含不定数量参数的自定义函数,使用一个数组作为最后一个(或惟一的)参数,并在数组前面加上关键字ParamArray。关键字ParamArray只能用于参数列表中的最后一个参数,其数据类型总是Variant并且是一个可选的参数。
MSCBSC | 移动通信网A8O A(d5W{[6、在自定义函数的程序代码中,应确保至少有一次把合适的值赋给了函数的名称。
j1[1z8J^:Mc/N%f9F07、函数的名称必须遵循一定的规则(与变量名称相同)。最好不要采取与单元格地址相同的形式,并且还要避免使用与Excel内置函数名称相同的名称,否则,Excel会使用内置函数。
;Bbo%C*s.]H08、如果想将Case关键字和相应的语句放在同一行上,在Case语名与相应语句间加上分隔符冒号(

。
F#rOZh6v09、通常情况下,VBA中对文本进行比较等操作是区分大小写的,若将语句Option Compare Text添加到模块的顶部,则程序执行时不会区分大小写。
*ia@}!r.`l%D2nI010、要处理单元格区域,在代码中不必先选项中该单元格区域。
-uK m5S&w5@:a0@*x-w"I.sT0MSCBSC | 移动通信网$LDfupOB
E1、编写自定义函数时,必须在VBA模块中,而不是在与ThisWorkbook、工作表和用户窗体关联的代码模块中。
MSCBSC | 移动通信网r0rS(aJ"Y2、如果代码要选中单元格区域,则该区域所在的工作表必须是活动的,可以使用Activate方法来激活某工作表。
wHON:C|4Z03、尽量在VBA代码中使用命名的单元格区域。
&iK4Ade|-i04、当通过快捷键选择单元格区域的时候,如果用宏录制器生成代码,则要认真检查代码中是否有对选中的实际单元格录制硬编码的引用。
MSCBSC | 移动通信网 n.@%s-Hv}:U8y6Z5、如果某个宏应用于当前单元格区域中的每个单元格,但用户可能会选中整行或整列,通常,我们不需要遍历选区中的每个单元格,那么这个宏应创建一个子选区,使其只由非空单元格组成。
MSCBSC | 移动通信网b8Dt
?6Y'z*R2J!B6、Excel允许同时有多个选区。
MSCBSC | 移动通信网\\(HPQufB P7、若定义了单元格区域的名称,则在代码中使用定义的名称时,即使在名称单元格区域中添加或删除了行或列,也能确保正确使用该单元格区域。
MSCBSC | 移动通信网x7y1D1XkI^;f8、在VBA代码中使用注释,可以简要描述编写的每个过程的目的、对过程所做的任何修改、描述变量的目的等。
E^*{n1^'ir)F0通过使用VBE中“编辑”工具栏的“设置注释块/解除注释块”,也可以将VBA语句暂时设置成注释块,以便于调试。
MSCBSC | 移动通信网Bm2Z#Qu+]6p9、在工作表中编辑控件。在拖动控件的同时按Alt键,按钮将与工作表的网格线对齐;在拖动的同时按Shift键,按钮成正方形
vG9qt} Guz010、通常,将Application对象的EnableEvents属性设置为False即可禁止事件发生。但要注意的是,这个属性只对真正的Excel对象(如Workbooks,Worksheets,Charts等)的事件产生作用。