如何在VBA中实现工作表函数SIGN
创始人
2024-03-13 21:17:08

Excel中有一个公式sign,其返判断数字的符号,正数返回值为1,负数返回值为-1,0返回值为0。

但是在VBA中即无法使用Application.WorksheetFunction调用工作表函数,也没有提供相应的VBA函数实现此功能,也许MS的产品经理认为根本不需要这个功能,呵呵。

前一阵子在论坛看板有个帖子就是关于这个的提问,其实实现起来也很简单,单行IIF嵌套就可以实现,代码如下。

Sub demo1()n = 0Debug.Print IIf(n < 0, -1, IIf(n = 0, 0, 1))n = 100Debug.Print IIf(n < 0, -1, IIf(n = 0, 0, 1))n = -100Debug.Print IIf(n < 0, -1, IIf(n = 0, 0, 1))
End Sub

运行实例代码,结果如下。

0
1
-1

IIF用法很简单,这里就不再赘述。

这里给大家提供一个另类的实现思路,利用逻辑值TrueFalse的整数值,也可以快速实现符号判断,代码如下。

Sub demo2()n = 0Debug.Print Int(n < 0) - Int(n > 0)n = 100Debug.Print Int(n < 0) - Int(n > 0)n = -100Debug.Print Int(n < 0) - Int(n > 0)
End Sub

需要大家注意的是TrueFalse的整数值为-10,通过组合两个判断条件,然后将逻辑值进行运算,得到相应的结果。

相关内容

热门资讯

省委部署开展持续深化违规吃喝问... 转自:中安在线近日,省委办公厅印发《关于巩固拓展深入贯彻中央八项规定精神学习教育成果持续深化违规吃喝...
智者勇进•接续奋进新江苏|用数... 转自:扬子晚报在城市加速转型、发展方式不断更新迭代的当下,雨花台区把“数智”作为提升城市运行效率的重...
中创智领:董事长、副总经理拟合... 转自:贝壳财经新京报贝壳财经讯 12月21日,中创智领公告称,董事长焦承尧、副总经理付奇和张海斌因个...
广深港高铁客流破纪录:3000... 12月20日,从广州南发出的G6541次列车准时抵达香港西九龙站,来自香港南元朗官立小学的近百名学生...
加科思-B(01167)附属与... 加科思-B(01167)公布,该集团的非全资附属公司北京加科思新药研发有限公司与AstraZenec...