excel - 计算器不会执行基本的算术计算
问题描述
我对 VBA 比较陌生,并且一直在努力学习它。我首先尝试编写一个计算器并对其进行编程以执行基本计算,例如加法、除法、减法和乘法。但是,当我尝试使用下面的代码执行这些功能时,计算器不会编译并执行上述计算。
Private Sub cmdBtnEql_Click()
On Error GoTo ErrOcccered
If txtDisplay = "Cannot divide by Zero" Then txtDisplay = Empty
If txtRes <> "" And calVal Then
FNum = Val(txtDisplay): SNum = Val(txtRes)
Select Case calVal
Case "Add"
txtRes = FNum + SNum
Case "Minus"
txtRes = FNum - SNum
Case "Multiplication"
txtRes = FNum * SNum
Case "Divide"
If SNum = 0 Then
txtRes = "Cannot divide by zero"
Else
txtRes = FNum / SNum
End If
Case Else
End Select
End If
ErrOcccered:
End Sub
然而,这个过程实际上并不执行上述计算。我可以单击按钮,并且相应的数字确实显示在用户表单的文本框中,没有进行任何计算。这段代码不是我个人的,我正在使用我在网上找到的另一个代码,并试图了解所有语法和语义在 VBA 中是如何工作的。我感谢您的帮助!谢谢
解决方案
在代码的这一行放置一个断点。
If txtRes <> "" And calVal Then
使用 F8 单步执行您的代码并找出它的确切作用。
你会发现它永远不会超过这条线,因为有一个测试是否calVal
有一个不是零的值。当然,calVal 应该包含一个单词,例如“Add”,因此永远不能有除零以外的数值。
将此测试更改为
If txtRes <> "" And len(calVal) > 0 Then
但仍然使用 F8 的方法来检查您的代码。
顺便说一句,txtRes = FNum + SNum
在技术上是正确的,但实际上令人困惑。上面的一位评论员将 txtRes 误认为是一个变量。更好的语法是在代码中包含默认属性。
txtRes.Value = FNum + SNum
推荐阅读
- opencv - 如何在二进制分割图像中分割连接和重叠的对象?
- javascript - React Material Ui 对话框未显示正确的值
- angular - mat-tab-group 不是 Angular 9 中的已知元素
- google-tag-manager - Google Tag Manager:如何访问存储在数组中的购物篮内容?
- java - 如何将此过滤器从特定 AD 组更改为组织中的所有 AD 组?
- java - 无法使用 Selenium Java webdriver 单击锚点 href 元素
- javascript - 如何将电话号码显示为移动设备而不是桌面设备上的链接?
- c++ - 2D 矢量声明给出类型规范错误
- ionic-framework - 离子打印机它不打印单个元素
- c++ - 如果禁止动态内存分配,程序会是什么样子?