RSS
热门关键字:  google  网站  电子书籍  电子杂志  网赚
当前位置 : 主页>>网络服务>>网站知识>>列表

实现搜索结果的关键词变色标注的程序

来源: 作者:vimhoo 时间:2007-12-30 点击:

〈%
'' 以前写全文检索程序的时候写的.
'' 原创 by 飞鸟@dev-club.com
'' Email: flybird@dev-club.com
'' ie5.5 脚本引擎 required

  dim patern
  dim found
  
  dim str
  dim result
  
  patern="(a)|(b)"
  str=" A dog fall in love with a cat. Can you believe?"
  result=""  
  call getMatchText(str,result,false)
  Response.Write result

  sub getMatchText(byref str,byref result,isNeedTrunc)
    ''on error resume next
    Dim regEx, Match, Matches
    dim tStr
    Set regEx = New RegExp     '' 建立正则表达式。    
    regEx.Pattern = (patern)  '' 设置模式。
    regEx.IgnoreCase = True     '' 设置是否区分字符大小写。
    regEx.Global = True     '' 设置全局可用性。
    Set Matches = regEx.Execute(str)  '' 执行搜索。  
    if err.number〈〉0 then
      response.write "错误1:" & err.description
      err.clear
      exit sub
    end if
    if matches.count 〈〉0 then
      dim startIndex      
      dim myMatchValue
      startIndex=1
      for each match in matches
        if (instr(str,match.value)〉0) then
          if instr(str,match.value)-50 〉0 then
            startIndex=instr(str,match.value)-50
          else
            startIndex=1
          end if
          myMatchValue=match.value
          exit for
        end if
      next
      if isNeedTrunc then
        result= (mid(str,startIndex,strLength(myMatchValue)+100))
      else
        result= (str)  
      end if
      for each match in matches
        if not(instr(result,"〈font color=red〉" & match.value & "〈/font〉")〉0) then
          result=replace(result,match.value,"〈font color=red〉" & match.value & "〈/font〉" )
        end if
      next
      found=true
    else
      found=false
    end if  
    set regEx=nothing
  end sub
  
%〉

最新评论共有 0 位网友发表了评论
发表评论
评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
用户名: 密码:
匿名?
注册