文档库 最新最全的文档下载
当前位置:文档库 › VBA编程规则及方法技巧

VBA编程规则及方法技巧

VBA编程规则及方法技巧 加入收藏
网站地图
网站搜索

简 繁 默

excel资源下载首页 excel教程下载专区 excel函数、VBA、技巧视频教程 excel函数学习资料 excel财务会计报表模板
返回excel论坛 VBA学习资料 Excel图表专区 excel在线学习 Excel技巧全接触 excel办公常用表格
Excel在线帮助 VBA在线帮助 excel2007精华教程 Excel电子表格问题解答
Excel函数应用手册

excel → VBA学习资料

阅读新闻



VBA编程规则及方法技巧
[日期:2007-07-09]来源: 作者:佚名[字体:大 中 小]

1、在自定义函数前加上Private关键字进行声明,该函数将不会出现在Excel的“粘贴函数”对话框中,但仍然可以在公式中运用它们。如果是专门为其他的VBA过程开发的自定义函数,则应该使用Private关键字进行声明。
2、
通常,用户自定义函数后,在“粘贴函数”对话框中将会出现在“用户定义”类别中。如果希望自定义函数出现在其它的类别中,必须编写和执行VBA代码为自定
义函数指定类别。如运行Application.MacroOptions
Macro:=”SumPro”,Category:=4语句后,将自定义的SumPro函数指定给“统计函数”类别。
3、与Sub过程不同,自
定义函数Function过程并不出现在宏对话框中;当执行VBE编辑器中的“运行——运行子过程/用户窗体”命令时,如果光标位于某Function过
程中,就不能获取宏对话框并从中选择要运行的宏。因此,在开发过程的时候,必须采取其它方式对自定义函数进行测试,可以设置调用该函数的过程;如果该函数
是用在工作表公式中的,可以在工作表中输入简单的公式进行测试。
4、如果在公式中使用了自定义函数,但返回值“VALUE!”,表明函数中有错误。错误的原因可能是代码中的逻辑错误、可能给函数传递了不正确的参数、可能执行了禁用的动作如试图更改单元格的格式。
5、在自定义函数中使用参数时,可选参数必须在任何必需的参数之后。在参数名称前加上关键字Optional即可指定一个可选的参数。
如果必须确定某可选的参数是否传递给了某函数,应将该参数声明为Variant类型,然后在过程代码中使用IsMissing函数来进行判断。
要创建包含不定数量参数的自定义函数,使用一个数组作为最后一个(或惟一的)参数,并在数组前面加上关键字ParamArray。关键字ParamArray只能用于参数列表中的最后一个参数,其数据类型总是Variant并且是一个可选的参数。
6、在自定义函数的程序代码中,应确保至少有一次把合适的值赋给

了函数的名称。
7、函数的名称必须遵循一定的规则(与变量名称相同)。最好不要采取与单元格地址相同的形式,并且还要避免使用与Excel内置函数名称相同的名称,否则,Excel会使用内置函数。
8、如果想将Case关键字和相应的语句放在同一行上,在Case语名与相应语句间加上分隔符冒号(:)。
9、通常情况下,VBA中对文本进行比较等操作是区分大小写的,若将语句Option Compare
Text添加到模块的顶部,则程序执行时不会区分大小写。
10、要处理单元格区域,在代码中不必先选项中该单元格区域。



1、编写自定义函数时,必须在VBA模块中,而不是在与ThisWorkbook、工作表和用户窗体关联的代码模块中。
2、如果代码要选中单元格区域,则该区域所在的工作表必须是活动的,可以使用Activate方法来激活某工作表。
3、尽量在VBA代码中使用命名的单元格区域。
4、当通过快捷键选择单元格区域的时候,如果用宏录制器生成代码,则要认真检查代码中是否有对选中的实际单元格录制硬编码的引用。
5、如果某个宏应用于当前单元格区域中的每个单元格,但用户可能会选中整行或整列,通常,我们不需要遍历选区中的每个单元格,那么这个宏应创建一个子选区,使其只由非空单元格组成。
6、Excel允许同时有多个选区。
7、若定义了单元格区域的名称,则在代码中使用定义的名称时,即使在名称单元格区域中添加或删除了行或列,也能确保正确使用该单元格区域。
8、在VBA代码中使用注释,可以简要描述编写的每个过程的目的、对过程所做的任何修改、描述变量的目的等。
通过使用VBE中“编辑”工具栏的“设置注释块/解除注释块”,也可以将VBA语句暂时设置成注释块,以便于调试。
9、在工作表中编辑控件。在拖动控件的同时按Alt键,按钮将与工作表的网格线对齐;在拖动的同时按Shift键,按钮成正方形
10、通常,将Application对象的EnableEvents属性设置为False即可禁止事件发生。但要注意的是,这个属性只对真正的Excel对象(如Workbooks,Worksheets,Charts等)的事件产生作用。



阅读:2024 次
录入:admin



【 评论 】 【 推荐 】 【 打印 】
上一篇:excel vba常见问题50问50答
下一篇:VB中集合与类的完全教程(下载)


相关新闻


本文评论 全部评论


发表评论


点评: 字数
姓名:

尊重网上道德,遵守中华人民共和国的各项有关法

律法规
承担一切因您的行为而直接或间接导致的民事或刑事法律责任
本站管理人员有权保留或删除其管辖留言中的任意内容
本站有权在网站内转载或引用您的评论
参与本评论即表明您已经阅读并接受上述条款



站长统计


网站简介 - 广告服务 - 网站地图 - 帮助信息 - 联系方式
Copyright © iwms 
友情链接:
Powered by
豫ICP备07008583号iwms 4.4

相关文档