调试经验——将VBA子程序转换为自定义函数(Transforming sub procedure to custom function in Excel)

今天发现,可以很容易的将VBA子程序转换为自定义函数,从而可以在worksheet中方便的使用相应的功能。

比如,现有一个实现字符串逆序的子程序。

Sub reverseString()

Dim oStr As String
Dim oArr() As String
Dim rStr As String
Dim rArr() As String

oStr = "乡 ma 故 I 思头低 erofereht 月 kniht 明 I 望头举"
rStr = ""

ReDim oArr(1 To Len(oStr))
ReDim rArr(1 To Len(oStr))

For i = 1 To Len(oStr)
    oArr(i) = Mid(oStr, i, 1)
    rArr(Len(oStr) - i + 1) = oArr(i)
Next

For i = 1 To Len(oStr)
    rStr = rStr + rArr(i)
Next

Debug.Print "转换前的字符串:" & oStr & vbNewLine
Debug.Print "转换后的字符串:" & rStr & vbNewLine

End Sub

经过稍加修改,可以转换为自定义函数:

Function reverseStr(ByVal rng As Range)

Dim oStr As String
Dim oArr() As String
Dim rStr As String
Dim rArr() As String

oStr = rng.Value
rStr = ""

ReDim oArr(1 To Len(oStr))
ReDim rArr(1 To Len(oStr))

For i = 1 To Len(oStr)
    oArr(i) = Mid(oStr, i, 1)
    rArr(Len(oStr) - i + 1) = oArr(i)
Next

For i = 1 To Len(oStr)
    rStr = rStr + rArr(i)
Next

reverseStr = rStr
End Function

然后就可以在工作表中调用这一函数了:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值