我对 excel vba 还很陌生,我似乎无法用 vbArrays 解决这个问题。我在 vba 中创建了函数 cumsum 只是为了让我的生活更轻松。但是,我想让代码灵活,这样我就可以从一个函数和一个范围传递两个变体。在我的代码中,当我添加行 vec=vec.value 如果我传入一个范围时,它工作得非常好,但如果我希望它在我调用函数并传入非范围类型时工作,它就不起作用. 我注意到的是,如果我的代码中没有 vec=vec.value 行并且我传入一个范围,它的维度为 0,我通过编写自己的函数进行检查。有人可以向我解释如何解决这个问题吗?谢谢。
Public Function cumsum(vec As Variant) As Variant
Dim temp() As Variant
MsgBox (getDimension(vec))
'works if i use vec=vec.value if vec is a range but has 0 if i do not vec = vec.values
ReDim temp(LBound(vec, 1) To UBound(vec, 1), 1 To 1) As Variant
Dim intCounter As Integer
For intCounter = LBound(vec) To UBound(vec)
If intCounter = LBound(vec) Then
temp(intCounter, 1) = vec(intCounter, 1)
Else
temp(intCounter, 1) = temp(intCounter - 1, 1) + vec(intCounter, 1)
End If
Next
cumsum = temp()
End Function
Function getDimension(var As Variant) As Integer
On Error GoTo Err:
Dim i As Integer
Dim tmp As Integer
i = 0
Do While True:
i = i + 1
tmp = UBound(var, i)
Loop
Err:
getDimension = i - 1
End Function