VB里怎么查找一个指定字符存在多少个比如 1.txt 内容为
 235
34673788在上面输入7 然后查找 怎么能得到有2个

解决方案 »

  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.   

    写个循环,每次改变的是start,循环结束的标志是InStr返回0
      

  3.   

    Private Sub readTxt()
        Dim strFilename As String '文件名
        Dim lngHandle As Long '文件句柄
        Dim strLine As String '在循环中存放每行的内容
        Dim sum1 As Integer
        
        sum1 = 0
        strFilename = App.Path & "\log.txt"
        '获得文件的句柄
        lngHandle = FreeFile()
        'For后面的参数表示以何种方式打开文件,Input是读取,Output是覆盖写入,Append是追加写入
        Open strFilename For Input As lngHandle    '循环直到文件尾
        Do While Not EOF(lngHandle)
            '每次读取一行存放在strLine变量中
            Line Input #lngHandle, strLine
            
        Do While InStr(strLine, "7") > 0
            sum1 = sum1 + 1
                strLine = Trim(Mid(strLine, InStr(strLine, "7") + 1))
        Loop
        Loop
        
        Close lngHandle    Debug.Print sum1
    End Sub
      

  4.   

    楼主这个也愁,一是文件操作,再就是一个循环语句中间包含一个函数的应用,试着自己写出代码我觉得对你更有帮助.楼上的代码,  Do While InStr(strLine, "7") > 0
            sum1 = sum1 + 1
                strLine = Trim(Mid(strLine, InStr(strLine, "7") + 1))
      Loop这就是你想要的关键
      

  5.   

    把luyin2002(绿荫) 代码中的
    Dim sum1 As Integer
    改为
    Dim sum1 As Long