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

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,通过组合两个判断条件,然后将逻辑值进行运算,得到相应的结果。

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...