编写简单的excel自定义函数

编写简单的excel自定义函数

ID:20009161

大小:309.50 KB

页数:5页

时间:2018-10-08

编写简单的excel自定义函数_第1页
编写简单的excel自定义函数_第2页
编写简单的excel自定义函数_第3页
编写简单的excel自定义函数_第4页
编写简单的excel自定义函数_第5页
资源描述:

《编写简单的excel自定义函数》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、下面通过一个例子来学习简单的编写自定义函数例:下面表格中需要计算一些三角形的面积B列是底边长,C列是高,要求在D列通过公式计算三角形面积。(通常我们会在D3单元格用公式=B3*C3/2来计算,然后把这个公式向D列下方拖动复制,得到其他公式。这只是一个简单的例子,通过它来学习编写简单的自定义函数)1.1、打开VBA窗口按ALT+F11调出VBA窗口,插入一个用户模块。2.2、编写代码通常自定义函数是用function命令开始的,在这个命令后面给它指定一个名字和参数把下面这个自定义函数代码粘贴到刚插入的用户模块中就可以使用了。

2、Functionsjxmj(di,gao)sjxmj=di*gao/2EndFunction这段代码非常简单只有三行,先看第一行,其中sjxmj是自己取的函数名字,括号中的是参数,也就是变量,di表示“底边长”,gao表示“高”,两个参数用逗号隔开。再看第二行,这是计算过程,将di*gao/2这个公式赋值给sjxmj,即自定义函数的名字。再看第三行,它是与第一行成对出现的,当你手工输入第一行的时候,第三行的endfunction就会自动出现,表示自定义函数的结束。1.3、使用自定义函数回到EXCEL窗口,我们在D3单元格中

3、输入公式=sjxmj(b3,c3),就会得到这一行的三角形面积了,它的使用方法同内置函数完全一样。2.通过上面例子可以了解自定义函数的编写和使用方法,下面再介绍一个稍微复杂点的自定义函数。经常对数据进行处理的朋友可以会遇到多条件查找某一个数据,一般这种情况需要编写“数组公式”来解决,公式较长,也不易理解。比如下面统计成绩的表格,需要根据A1:D7的成绩表,统计出两门功能都在90分以上的学生人数。通常这种时候需要在H3单元格使用数组公式=SUM(IF(($B$2:$B$7=G3)*($D$2:$D$7>=90)*($E$2:

4、$E$7>=90),1,0))大家可以看到在H3单元格中的公式比较长,理解起来也有一定难度。我们通过自定义函数也可以得到正确结果,函数代码如下:Function统计(a,b,c,d,e)  Fori=1Toa.Rows.Count    Ifb=a.Cells(i,1)Anda.Cells(i,c)>=eAnda.Cells(i,d)>=eThen        统计=统计+1    EndIf  NextEndFunction这个函数用了五个参数(因为涉及到一个区域和四个条件)参数a表示要统计的区域,在此例中为B2:E7

5、参数b表示要统计的是哪一个班级,在此例中为G3单元格参数c表示数学成绩相对于区域第一列向右的列数,在此例中为3参数d表示数学成绩相对于区域第一列向右的列数,在此例中为4参数e表示分数,在此例中为90分提示:要注意参数c和d“相对”于“区域”的列数,并非是从A列开始向右的列数。把上面这段代码也粘贴到用户模块中就可以使用了回到EXCEL窗口,在H3单元格中输入公式=统计($B$2:$E$7,G3,3,4,90)就可以显示正确结果了。提示:如果我们的成绩表格式是固定的,各科目成绩位置相对于区域也是固定的,而且要统计的分数也是固定

6、的90分,就可以在自定义函数中将参数的数量减少到两个,如下:Function统计2(a,b)Fori=1Toa.Rows.CountIfb=a.Cells(i,1)Anda.Cells(i,3)>=90Anda.Cells(i,4)>=90Then统计=统计+1EndIfNextEndFunction在表格中的H3单元格中输入公式=统计2($B$2:$E$7,G3)就可以了。从上面可以看出,自定义函数可以使用“汉字”做为函数的名字,方便记忆,也可以根据实际情况对参数进行简化。我要求的是台数的和,公式中总是以金额×台数来表示

7、,单台的话无×号举例:50×3+40+30×4台数为3+1+4=850+40×3+30×4+45台数为1+3+4+1=9希望高手来帮忙啊,分不多,全献上了问题补充:分别放在不同的单元格里是可行的,不过我想采用自定函数的形式来求和,就像SUM()一样2010-9-1617:22最佳答案PublicFunctiongetn(s)Dimcc=Split(Replace(s.FormulaR1C1,"=",""),"+")ForEachiIncIfInStr(i,"*")<>0Thengetn=getn+Val(Mid(i,InS

8、tr(i,"*")+1,10))Elsegetn=getn+1EndIfNextEndFunction

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。