如何在excel表格中设置自定义函数

如题所述

Excel有虽然有自带函数库,并不是很够用,不能满足所有可能出现的情况,有时候就需要使用自定义函数。

1、打开Excel程序,点击“工具”中的“宏”,选择“Visual Basic编辑器”选项。(按“Alt+F11”快捷键也可以实现)。

2、会跳出“Visual Basic编辑器-Book1”窗口。在“Visual Basic编辑器-Book1”窗口中,点击“插入”中的“模块”项。


3、会跳出命令窗口。在“Book1-模块1(代码)”窗口里输入你需要自定义的函数:

(举个例子)这里求三角形面积

自定义函数是用function命令开始的,在这个命令后面给它指定一个名字和参数
输入内容如下:
Function S(a, h)
S = a* h / 2
End Function

这段代码非常简单只有三行,第一行,其中S是自己取的函数名字,括号中的是参数,也就是变量,a表示“底边长”,h表示“高”,两个参数用逗号隔开。
第二行,这是计算过程,将a*h/2这个公式赋值给S,即自定义函数的名字。
第三行,它是与第一行成对出现的,当你手工输入第一行的时候,第三行的end function就会自动出现,表示自定义函数的结束。

4、输入完毕,关闭窗口,自定义的函数就完成了。【你需要有一定的VB基础知识】

5、然后就是自定义函数实际的运用了,运用前可以做个简单的检验,看看是不是准确,一般来是不会错的。



有时候自定义复杂函数,需要基本的数学知识和VBA基础,这需要自身的日积月累了。

【注意事项】


      自定义的函数虽然可以像内置函数一样使用,不过却并不是真正的内置函数,只能用于当前工作簿。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-07-28

举例说明。

例如要做一个单元格求和的自定义函数,比sum函数增加一个条件,就是如果单元格有删除线标记,则不计入该单元格的数值。如图:

第一步:在visual basic模式下插入模块,并创建自定义函数。代码如下:

Public Function mysum(qu As Range)
Dim s As Double
Dim b
mysum = 0
For Each b In qu
If b.Font.Strikethrough = False Then
   mysum = mysum + b.Value
End If
Next
End Function

第二步:在c15单元格输入公式:=mysum(C4:C14)。结果如图:

第2个回答  2015-11-05

 (1)在编制好的Excel表格中的某一个单元格(例如D1)中输入“0.95”

(2)数据(例如B2)所在的行的空白单元格(C2)中输入“=B2*$D$1",按键盘上”回车“键,这时就完成单元格B2中的数据乘以0.95的操作

(3)选中单元格C2,将光标放到单元格C2的右下角,当出现”+“号后,按住鼠标左键往下拉动鼠标,这样就实现了”自动填充“功能,将一列数据中每一个单元格中数据乘以0.95。

备注:$D$1是绝对引用。

第3个回答  2016-12-22

自定义函数,一般用VB,下面以长方体的体积公式为例,详细一步步介绍

1、打开EXCLE后,按ALT+F11,打开“Visual Basic编辑器”

2、“Visual Basic编辑器”中,选择“插入”--“模块”

3、在如图的位置,输入以下代码         

Function MJ(a, b, c)

MJ = a * b * c

End Function


4、之后就可以在表格里直接引用此函数了

第4个回答  推荐于2018-06-18
  1、打开Excel程序,按键盘组合键“Alt+F11”或切换至“开发工具”功能区并点击“Visual Basic”按钮进入VBA环境。有关开启“开发工具”功能区的方法下面将会讲解。
  2、在VBA环境下,右击“MicrosoftExcel对象”,从弹出的菜单中选择“插入”->“模块”项。
  3、在打开的模块窗口中,输入以下代码:Function三项合并计算(a, b, c),三项合并计算 = a * b + c,End Function,该代码用于对提供的三个参数进行计算,结果返回函数本身。
  4、接着返回Excel界面,在单元格中输入公式“=三项合并计算(2,3,5)”并按回车键即可得结果。
  5、当然,我们还可以通过引用三个单元格数据来实现同样的计算功能:分别在A2、B2、C2单元格中输入2,3,5,在D2单元格中输入“”并按回车键即可得结果。
  6、如何开启“开发工具”功能区
  (1)点击“Office按钮”,在打开的扩展面板中点击“Excel选项”。
  (2)接着勾选“在功能区显示‘开发工具’选项卡”项即可。本回答被网友采纳
相似回答