我正在使用VBA的基本编码来创建一个模板,从Windows中的其他屏幕中提取数据。当它拉出数字时,它们被格式化为字符串。我现在需要将字符串转换为双精度数,以便加/减它们。我一直在尝试一切,但似乎无法弄明白。
Me.salesprice = Trim(scrn.GetString(11, 65, 10))
'This would be formatted as 25,000.00
Me.salestax = Trim(scrn.GetString(12, 66, 10))
Me.pastdue = Trim(scrn.GetString(14, 65, 10))
Me.assessedppt = Trim(scrn.GetString(18, 66, 10))
Me.secdep = Trim(scrn.GetString(17, 65, 10))
assessedppt = Convert.ToDouble(Me.assessedppt)
uappt = Convert.ToDouble(Me.uappt)
salesprice = Convert.ToDouble(Me.salesprice)
salestax = Convert.ToDouble(Me.salestax)
pastdue = Convert.ToDouble(Me.pastdue)
lc = Convert.ToDouble(frmDetails.lc)
totalfinance = salesprice + salestax + pastdue - secdep + assessedppt + uappt + lc
totalsalesprice = salesprice + pastdue
ppt = assessedppt + uappt
当我这样做时,我收到以下错误:
编译错误:未定义变量,它突出显示第一个 转换功能。
答案 0 :(得分:14)
您使用了错误的功能进行转换。你需要使用CDbl,在VBA中我们有以下转换函数:
numberDouble = CDbl("10") 'For convert to double
numberInteger = CInt("12") 'For convert to Integer
varString = CStr("11") 'For convert to String
bool = CBool("true") 'For convert to Boolean
因此,如果您更改Convert.toDouble,您的代码将如下所示:
Me.salesprice = Trim(scrn.GetString(11, 65, 10))
'This would be formatted as 25,000.00
Me.salestax = Trim(scrn.GetString(12, 66, 10))
Me.pastdue = Trim(scrn.GetString(14, 65, 10))
Me.assessedppt = Trim(scrn.GetString(18, 66, 10))
Me.secdep = Trim(scrn.GetString(17, 65, 10))
assessedppt = CDbl(Me.assessedppt.value)
uappt = CDbl(Me.uappt.value)
salesprice = CDbl(Me.salesprice.value)
salestax = CDbl(Me.salestax.value)
pastdue = CDbl(Me.pastdue.value)
lc = CDbl(frmDetails.lc.value)
totalfinance = salesprice + salestax + pastdue - secdep + assessedppt + uappt + lc
totalsalesprice = salesprice + pastdue
ppt = assessedppt + uappt
答案 1 :(得分:0)
这是基于我的other answer:
如果允许用户使用其他字符(例如 $
符号),则以下功能可能会很有用(结合Guilherme Felipe Reis's answer) :
'
' Skips all characters in the input string except
' the first negative-sign, digits, and the first dot
'
Function ParseNumber(ByVal s As String) As Double
ParseNumber = 0#
Dim char As String
Dim i As Integer
Dim digits$
Dim isNegative As Boolean
Dim isPastDot As Boolean
For i = 1 To Len(s)
char = Mid(s, i, 1)
If char >= "0" And char <= "9" Then
digits = digits + char
ElseIf char = "-" Then
If Len(digits) <= 0 Then
isNegative = True
End If
ElseIf char = "." Then
If Not isPastDot Then
isPastDot = True
digits = digits & "."
End If
End If
Next i
ParseNumber = CDbl(digits)
If isNegative Then
ParseNumber = 0 - ParseNumber
End If
End Function
答案 2 :(得分:-2)
看到这一点以及这些解决方案的详细程度,这很令人痛心!我希望这可以帮助某人...
Dim str_Impl_Vol As String ' let's say 37.9% is the string
Dim str_Impl_Vol = Left(ActiveSheet.Cells(intCurrentRow, intCol_Impl_Vol),
Len(ActiveSheet.Cells(intCurrentRow, intCol_Impl_Vol)) - 1)
' Remove the %
Dim dbl_Impl_Vol As Double ' let's say we need 37.9% as 0.379
dbl_Impl_Vol = CDbl(str_Impl_Vol / 100) ' just do it!
有什么问题吗?