求一个函数,功能是能在一个string里找到我想要的一串字符,例如:
<asfdfas>afadfdasf<abcdefaefawfwe>0.12345<sdfasdf>
我想要找的是"0.12345"也就是都是数字,有没有这样的函数?

解决方案 »

  1.   

    InStr 函数
          返回 Variant (Long),指定一字符串在另一字符串中最先出现的位置。语法 InStr([start, ]string1, string2[, compare])InStr 函数的语法具有下面的参数:部分 说明 
    start 可选参数。为数值表达式,设置每次搜索的起点。如果省略,将从第一个字符的位置开始。如果 start 包含 Null,将发生错误。如果指定了 compare 参数,则一定要有 start 参数。 
    string1 必要参数。接受搜索的字符串表达式。 
    string2 必要参数。被搜索的字符串表达式。 
    Compare 可选参数。指定字符串比较。如果 compare 是 Null,将发生错误。如果省略 compare,Option Compare 的设置将决定比较的类型。 
    设置 compare 参数设置为:常数 值 描述 
    vbUseCompareOption -1 使用Option Compare 语句设置执行一个比较。 
    vbBinaryCompare 0 执行一个二进制比较。 
    vbTextCompare 1 执行一个按照原文的比较。 
    vbDatabaseCompare 2 仅适用于Microsoft Access,执行一个基于数据库中信息的比较。 
    返回值如果 InStr返回 
    string1 为零长度 0 
    string1 为 Null Null 
    string2 为零长度 Start 
    string2 为 Null Null 
    string2 找不到 0 
    在 string1 中找到string2  找到的位置 
    start > string2 0 
    说明InStrB 函数作用于包含在字符串中的字节数据。所以 InStrB 返回的是字节位置,而不是字符位置。^_^
      

  2.   

    要找">&<"这个样子的字符串,&代表数字跟小数点
      

  3.   

    huangjianyou(小健):你说的函数我知道,但是我要找的不是固定的某个字符串,而是不确定的数字0-9还有小数点
      

  4.   

    要找个字符串是数字跟小数点组成的,而且在这个字符串两旁有">"and"<",明白我的意思了吗?
      

  5.   

    Dim i As Integer
    Dim StrArray(500) As Stringi = 0
    SouceString = Trim(SouceString)'get StrArray
    Do While Len(SouceString) <> 0
        StrArray(i) = Left(SouceString, 1)
        SouceString = Replace(SouceString, StrArray(i), "", 1, 1)
        i = i + 1
    Loopi = 0Do Until StrArray(i) = ""
        If StrArray(i) = ">" Then
            Do Until StrArray(i + 1) = "<"
                i = i + 1
                MaskStr = MaskStr + StrArray(i)
            Loop
            If IsNumeric(MaskStr) = True Then
                Exit Do
            Else
                MaskStr = ""
            End If
            i = i + 1
        Else
            i = i + 1
        End If
    Loop扫一行进去找出带有><的数字,返回MaskStr