【VBA研究】VBA从字符串中取出数据信息的函数

作者:iamlaosong

一个简单的函数,从包含有数字信息的字符串中取出这个数据,利用VAL函数将字符串转换为数值,该函数或略数字字符串后面的字母和汉字信息,所以,只要把数字前面的字母和汉字信息去掉就行了。


 '函数,从字符串“ABC123456.78DEF”中取出数据
Function mydata(mystring As String) As Double
    Dim i, k As Integer
    i = 1
    k = Len(mystring)
    Do Until Val(Mid(mystring, i, 1)) > 0 Or i > k
        i = i + 1
    Loop
    If i <= k Then
        mydata = Val(Right(mystring, Len(mystring) - i + 1))
    Else
        mydata = 0
    End If
End Function

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VBA,将16进制字符串转换成文需要进行以下几个步骤: 1. 首先,将16进制字符串拆分成每两个字符的子字符串。例如,将字符串"e4b8ade59bbde4b893"拆分成["e4", "b8", "ad", "e5", "9b", "bd", "e4", "b8", "93"]。 2. 然后,循环遍历每个子字符串,并将其转换成对应的16进制数值。可以使用VBA的Hex函数字符串转换成对应的数值。 3. 接着,将得到的16进制数值转换成字节。可以使用VBA的Chr函数将数值转换成字节。 4. 最后,将字节转换成文字符。可以使用VBA的StrConv函数将字节转换成Unicode字符。 下面是一个示例代码,实现将16进制字符串转换成文的操作: ```vba Sub ConvertHexToChinese() Dim hexString As String Dim result As String hexString = "e4b8ade59bbde4b893" result = "" For i = 1 To Len(hexString) Step 2 num = "&H" & Mid(hexString, i, 2) '将子字符串转换成对应的16进制数值 byteValue = Chr(num) '将16进制数值转换成字节 chineseChar = StrConv(byteValue, vbUnicode) '将字节转换成Unicode字符 result = result & chineseChar Next i MsgBox result '输出结果 End Sub ``` 在上述示例代码,我们使用了一个名为`hexString`的变量来保存需要转换的16进制字符串。然后,我们创建了一个名为`result`的变量来保存转换后的字符串。在循环遍历每个子字符串时,我们将其转换成对应的16进制数值,并使用`Chr`函数将其转换成字节。最后,通过`StrConv`函数将字节转换成Unicode字符,并将转换后的字符追加到`result`变量。最终,我们通过`MsgBox`函数将转换后的字符串输出到对话框。 希望以上内容能够对您有所帮助。如果有任何疑问,请随时追问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值