<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      asp中正則表達式的應用

      [摘要]asp中正則表達式的應用一、正則表達式概述 二、正則表達式在VBScript中的應用 三、正則表達式在VavaScript中的應用 四、示例 五、總結 一、正則表達式概述 如果原來沒有使...

      asp中正則表達式的應用一、正則表達式概述 
      二、正則表達式在VBScript中的應用 
      三、正則表達式在VavaScript中的應用 
      四、示例 
      五、總結 

      一、正則表達式概述 
      如果原來沒有使用過正則表達式,那么可能對這個術語和概念會不太熟悉。不過,它們并不是您想象的那么新奇。 
      請回想一下在硬盤上是如何查找文件的。您肯定會使用 ? 和 * 字符來幫助查找您正尋找的文件。? 字符匹配文件名 
      中的單個字符,而 * 則匹配一個或多個字符。一個如 'data?.dat' 的模式可以找到下述文件:data1.dat、data2.dat等 
      等。如果使用 * 字符代替 ? 字符,則將擴大找到的文件數量。'data*.dat' 可以匹配下述所有文件名:data.dat、 
      data1.dat、data12.dat等等,盡管這種搜索文件的方法肯定很有用,但也十分有限。? 和 * 通配符的有限能力可以使你 
      對正則表達式能做什么有一個概念,不過正則表達式的功能更強大,也更靈活。 
      在我們編寫ASP程序時,經常會判斷一個字符串的有效性,如;一個串是否是數字、是否是有效的Email地址等等。如 
      果不使用正則表達式,那么判斷的程序會很長,并且容易出錯,如果使用正則表達式,這些判斷就是一件很輕松的工作 
      了。后面我們將介紹如何判斷數字和Email地址的有效性。 
      在典型的搜索和替換操作中,必須提供要查找的確切文字。這種技術對于靜態文本中的簡單搜索和替換任務可能足夠 
      了,但是由于它缺乏靈活性,因此在搜索動態文本時就有困難了,甚至是不可能的。 
      使用正則表達式,能完成些什么事情呢? 
      測試字符串的某個模式。例如,可以對一個輸入字符串進行測試,看在該字符串是否存在一個電話號碼模式或一個信 
      用卡號碼模式。這稱為數據有效性驗證。 
      替換文本?梢栽谖臋n中使用一個正則表達式來標識特定文字,然后可以全部將其刪除,或者替換為別的文字。 
      根據模式匹配從字符串中提取一個子字符串?梢杂脕碓谖谋净蜉斎胱侄沃胁檎姨囟ㄎ淖帧 
      例如,如果需要搜索整個 web 站點來刪除某些過時的材料并替換某些HTML 格式化標記,則可以使用正則表達式對每 
      個文件進行測試,看在該文件中是否存在所要查找的材料或 HTML 格式化標記。用這個方法,就可以將受影響的文件范圍 
      縮小到包含要刪除或更改的材料的那些文件。然后可以使用正則表達式來刪除過時的材料,最后,可以再次使用正則表達 
      式來查找并替換那些需要替換的標記。 
      那么,正則表達式語法的語法是如何呢? 
      一個正則表達式就是由普通字符(例如字符 a 到 z)以及特殊字符(稱為元字符)組成的文字模式。該模式描述在查找文 
      字主體時待匹配的一個或多個字符串。正則表達式作為一個模板,將某個字符模式與所搜索的字符串進行匹配。 
      這里有一些可能會遇到的正則表達式示例: 
      /^\[ \t]*$/ "^\[ \t]*$" 匹配一個空白行。 
      /\d{2}-\d{5}/ "\d{2}-\d{5}" 驗證一個ID 號碼是否由一個2位數字,一個連字符以及一個5位數字組成。 
      /<(.*)>.*<\/\1>/ "<(.*)>.*<\/\1>" 匹配一個 HTML 標記。 

      二、正則表達式在VBScript中的應用 
      VBScript使用RegExp對象、Matches集合以及Match對象提供正則表達式支持功能。我們還是先看一個例子。 
      <%
      Function RegExpTest(patrn, strng)
      Dim regEx, Match, Matches '建立變量。
      Set regEx = New RegExp '建立正則表達式。
      regEx.Pattern = patrn'設置模式。
      regEx.IgnoreCase = True '設置是否區分字符大小寫。
      regEx.Global = True '設置全局可用性。
      Set Matches = regEx.Execute(strng)'執行搜索。
      For Each Match in Matches'遍歷匹配集合。
      RetStr = RetStr & "Match found at position "
      RetStr = RetStr & Match.FirstIndex & ". Match Value is '"
      RetStr = RetStr & Match.Value & "'." & "
      "
      Next
      RegExpTest = RetStr
      End Function
      response.write RegExpTest("[ij]s.", "IS1 Js2 IS3 is4")
      %> 
      在這個例子中,我們查找字符串中有無is或者js這兩個詞,忽略大小寫。運行的結果如下: 
      Match found at position 0. Match Value is 'IS1'. 
      Match found at position 4. Match Value is 'Js2'. 
      Match found at position 8. Match Value is 'IS3'. 
      Match found at position 12. Match Value is 'is4'. 
      下面我們就介紹這三個對象和集合。 
      1、RegExp對象是最重要的一個對象,它有幾個屬性,其中: 
      ○Global 屬性,設置或返回一個 Boolean 值,該值指明在整個搜索字符串時模式是全部匹配還是只匹配第一個。如 
      果搜索應用于整個字符串,Global 屬性的值為 True,否則其值為 False。默認的設置為 False。 
      ○IgnoreCase 屬性,設置或返回一個Boolean值,指明模式搜索是否區分大小寫。如果搜索是區分大小寫的,則 
      IgnoreCase 屬性為 False;否則為 True。缺省值為 False。 
      ○Pattern 屬性,設置或返回被搜索的正則表達式模式。必選項?偸且粋 RegExp 對象變量。 
      2、Match 對象 
      匹配搜索的結果是存放在Match對象中,提供了對正則表達式匹配的只讀屬性的訪問。 Match 對象只能通過 RegExp 
      對象的 Execute 方法來創建,該方法實際上返回了 Match 對象的集合。所有的 Match 對象屬性都是只讀的。在執行正則 
      表達式時,可能產生零個或多個 Match 對象。每個 Match 對象提供了被正則表達式搜索找到的字符串的訪問、字符串的 
      長度,以及找到匹配的索引位置等。 
      ○FirstIndex 屬性,返回在搜索字符串中匹配的位置。FirstIndex 屬性使用從零起算的偏移量,該偏移量是相對于 
      搜索字符串的起始位置而言的。換言之,字符串中的第一個字符被標識為字符 0 
      ○Length 屬性,返回在字符串搜索中找到的匹配的長度。 
      ○Value 屬性,返回在一個搜索字符串中找到的匹配的值或文本。 
      3、Matches 集合 
      正則表達式 Match 對象的集合。Matches 集合中包含若干獨立的 Match 對象,只能使用 RegExp 對象的 Execute 方 
      法來創建之。與獨立的 Match 對象屬性相同,Matches `集合的一個屬性是只讀的。在執行正則表達式時,可能產生零個 
      或多個 Match 對象。每個 Match 對象都提供了與正則表達式匹配的字符串的訪問入口、字符串的長度,以及標識匹配位 
      置的索引。 
      學習了這三個對象和集合,如何應用于字符串的判斷和替換呢?regExp對象的三個方法正好解決了這個問題,它們是 
      Replace方法、Test方法和Execute方法。 
      1、Replace 方法 
      替換在正則表達式查找中找到的文本。我們還是先看個例子:下面的例子說明了 Replace 方法的用法。 
      <%
      Function ReplaceTest(patrn, replStr)
      Dim regEx, str1 ' 建立變量。
      str1 = "The quick brown fox jumped over the lazy dog."
      Set regEx = New RegExp ' 建立正則表達式。
      regEx.Pattern = patrn ' 設置模式。
      regEx.IgnoreCase = True ' 設置是否區分大小寫。
      ReplaceTest = regEx.Replace(str1, replStr) ' 作替換。
      End Function
      Response.write ReplaceTest("fox", "cat") & "
      " ' 將 'fox' 替換為 'cat'。
      Response.write ReplaceTest("(\S+)(\s+)(\S+)", "$3$2$1") ' 交換詞對.
      %> 
      2、Test 方法 
      對指定的字符串執行一個正則表達式搜索,并返回一個 Boolean 值指示是否找到匹配的模式。正則表達式搜索的實際 
      模式是通過RegExp對象的Pattern屬性來設置的。RegExp.Global屬性對Test方法沒有影響。 
      如果找到了匹配的模式,Test方法返回True;否則返回False。下面的代碼說明了Test 方法的用法。 
      <%
      Function RegExpTest(patrn, strng)
      Dim regEx, retVal ' 建立變量。
      Set regEx = New RegExp ' 建立正則表達式。
      regEx.Pattern = patrn ' 設置模式。
      regEx.IgnoreCase = False ' 設置是否區分大小寫。
      retVal = regEx.Test(strng) ' 執行搜索測試。
      If retVal Then
      RegExpTest = "找到一個或多個匹配。"
      Else
      RegExpTest = "未找到匹配。"
      End If
      End Function
      Response.write RegExpTest("is.", "IS1 is2 IS3 is4")
      %> 
      3、Execute 方法 
      對指定的字符串執行正則表達式搜索。正則表達式搜索的設計模式是通過 RegExp 對象的 Pattern 來設置的。 
      Execute 方法返回一個 Matches 集合,其中包含了在 string 中找到的每一個匹配的 Match 對象。如果未找到匹 
      配,Execute 將返回空的 Matches 集合。 

      三、JavaScript中正則表達式的使用 
      在JavaScript 1.2版以后,JavaScript也支持正則表達式。 
      1、replace 
      replace在一個字符串中通過正則表達式查找替換相應的內容。replace并不改變原來的字符串,只是重新生成了一個 
      新的字符串。如果需要執行全局查找或忽略大小寫,那么在正則表達式的最后添加g和i。 
      例: 
      <SCRIPT> 
      re = /apples/gi; 
      str = "Apples are round, and apples are juicy."; 
      newstr=str.replace(re, "oranges"); 
      document.write(newstr) 
      </SCRIPT> 
      結果是:"oranges are round, and oranges are juicy." 
      例: 
      <SCRIPT> 
      str = "Twas the night before Xmas..."; 
      newstr=str.replace(/xmas/i, "Christmas"); 
      document.write(newstr) 
      </SCRIPT> 
      結果是:"Twas the night before Christmas..." 
      例: 
      <SCRIPT> 
      re = /(\w+)\s(\w+)/;str = "John Smith"; 
      newstr = str.replace(re, "$2, $1"); 
      document.write(newstr) 
      </SCRIPT> 
      結果是:"Smith, John". 
      2、search 
      search通過正則表達式查找相應的字符串,只是判斷有無匹配的字符串。如果查找成功,search返回匹配串的位置, 
      否則返回-1。 
      search(regexp) 
      <SCRIPT> 
      function testinput(re, str){ 
      if (str.search(re) != -1) 
      midstring = " contains "; 
      else 
      midstring = " does not contain "; 
      document.write (str + midstring + re.source); 

      testinput(/^[1-9]/i,"123") 
      </SCRIPT> 
      3、match 
      match方法執行全局查找,查找結果存放在一個數組里。 
      例一: 
      <SCRIPT> 
      str = "For more information, see Chapter 3.4.5.1"; 
      re = /(chapter \d+(\.\d)*)/i; 
      found = str.match(re); 
      document.write(found); 
      </SCRIPT> 
      顯示結果:Chapter 3.4.5.1,Chapter 3.4.5.1,.1 
      例二: 
      <SCRIPT> 
      str = "abcDdcba"; 
      newArray = str.match(/d/gi); 
      document.write(newArray); 
      </SCRIPT> 
      顯示結果D, d. 

      四、示例 
      1 、判斷數字的正確性 
      <%@ Language=VBScript %> 
      <script language="javascript" runat="server"> 
      function isNumeric(strNumber) { 
      return (strNumber.search(/^(- \+)?\d+(\.\d+)?$/) != -1); 

      function isUnsignedNumeric(strNumber) { 
      return (strNumber.search(/^\d+(\.\d+)?$/) != -1); 

      function isInteger(strInteger) { 
      return (strInteger.search(/^(- \+)?\d+$/) != -1); 

      function isUnsignedInteger(strInteger) { 
      return (strInteger.search(/^\d+$/) != -1); 

      </script> 
      <HTML> 
      <BODY> 
      判斷數字的正確性 
      <%
      Dim strTemp
      strTemp = CStr(Request.Form("inputstring"))
      If strTemp = "" Then strTemp = "0"
      %> 
      <TABLE BORDER="1" CELLPADDING="4" CELLSPACING="2"> 
      <TR> 
      <TD ALIGN="right">原始字符串</TD> 
      <TD><%= strTemp %></TD> 
      </TR> 
      <TR> 
      <TD ALIGN="right">數字</TD> 
      <TD><%=isNumeric(strTemp)%></TD> 
      </TR> 
      <TR> 
      <TD ALIGN="right">非負數字</TD> 
      <TD><%=isUnsignedNumeric(strTemp)%></TD> 
      </TR> 
      <TR> 
      <TD ALIGN="right">整數</TD> 
      <TD><%=isInteger(strTemp)%></TD> 
      </TR> 
      <TR> 
      <TD ALIGN="right">非負整數()</TD> 
      <TD><%=isUnsignedInteger(strTemp)%></TD> 
      </TR> 
      </TABLE> 
      <FORM ACTION="<%=Request.ServerVariables("SCRIPT_NAME")%>" METHOD="post"> 
      請輸入一個數字:
       
      <INPUT TYPE="text" NAME="inputstring" SIZE="50"></INPUT>
       
      <INPUT TYPE="submit" Value="提交"></INPUT>
       
      </FORM> 
      </BODY> 
      </HTML> 
      2、判斷Email地址的正確性 
      <%
      Function isemail(strng)
      isemail = false
      Dim regEx, Match
      Set regEx = New RegExp
      regEx.Pattern = "^\w+((-\w+) (\.\w+))*\@[A-Za-z0-9]+((\. -)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$"
      regEx.IgnoreCase = True
      Set Match = regEx.Execute(strng)
      if match.count then isemail= true
      End Function
      %>


      五、總結 
      上面我們介紹了正則表達式的基本概念,以及在VBScript和JavaScript中如何使用正則表達式,同時,通過一些實例 
      讓大家有了感性的認識。正則表達式的應用范圍很廣,能為大家解決很多實際中的問題。本文介紹的內容只是一些初步的 
      知識,還有很多語法規則需要大家繼續學習,在實踐中發現問題,解決問題。 返回頂部 



      怎么實現數據記錄的分頁顯示(作者:DarkMan) 

      怎么實現數據記錄的分頁顯示 (1) 

      通過Recordset的GetRows方法,可以實現數據記錄的分頁顯示。下面是一個完整的例子: 
      <%@ Language = VBSCRIPT %> 
      <% Option Explicit %> 
      <%
      Dim iStart, iOffset
      iStart = Request("Start")
      iOffset = Request("Offset")

      if Not IsNumeric(iStart) or Len(iStart) = 0 then
      iStart = 0
      else
      iStart = CInt(iStart)
      end if

      if Not IsNumeric(iOffset) or Len(iOffset) = 0 then
      iOffset = 10
      else
      iOffset = Cint(iOffset)
      end if

      Response.Write "察看 " & iOffset & " 個記錄從 " & iStart & "開始
      "

      Dim objConn, objRS
      Set objConn = Server.CreateObject("ADODB.Connection")
      objConn.Open "Provider=SQLOLEDB.1;Data Source=(local);uid=sa;pwd=;Initial Catalog=pubs"

      Set objRS = Server.CreateObject("ADODB.Recordset")
      objRS.Open "SELECT * FROM Authors", objConn

      Dim aResults
      aResults = objRS.GetRows

      objRS.Close
      Set objRS = Nothing

      objConn.Close
      Set objConn = Nothing

      Dim iRows, iCols, iRowLoop, iColLoop, iStop
      iRows = UBound(aResults, 2)
      iCols = UBound(aResults, 1)

      If iRows > (iOffset + iStart) Then 
      iStop = iOffset + iStart - 1 
      Else 
      iStop = iRows 
      End If 

      For iRowLoop = iStart to iStop 
      For iColLoop = 0 to iCols 
      Response.Write aResults(iColLoop, iRowLoop) & " " 
      Next 
      Response.Write "

      Next 

      Response.Write "<P>" 
      if iStart > 0 then 
      '顯示“前 10個”連接 
      Response.Write "<A HREF=""paging.asp?Start=" & iStart-iOffset & _
      "&Offset=" & iOffset & """>前 " & iOffset & "" 
      end if 

      if iStop < iRows then
      '顯示“后 10個”連接
      Response.Write " <A HREF=""paging.asp?Start=" & iStart+iOffset & _
      "&Offset=" & iOffset & """>后 " & iOffset & "" 
      end if 
      %> 


      怎么實現數據的分頁顯示(2) 
      這里介紹另外一種分頁顯示的方法,是通過 MS SQL的存儲過程。本方法不適用于Access數據庫。 
      假設我們要對數據表MyTable的數據實現分頁顯示,首先寫一個存儲過程 如下: 
      CREATE PROCEDURE sp_PagedItems 

      @Page int, 
      @RecsPerPage int 

      AS 

      -- 加快表的 插入速度 
      SET NOCOUNT ON 

      -- 開始記錄 號 
      DECLARE @RecCount int 
      SELECT @RecCount = @RecsPerPage * @Page + 1 

      --創建臨時 表 
      CREATE TABLE #TempItems 

      ID int IDENTITY, 
      Name varchar(50), 
      Price currency 


      -- 準備臨時 表 
      INSERT INTO #TempItems (Name, Price) 
      SELECT Name,Price FROM MyTable ORDER BY Price 

      -- 求出要查 詢的最小ID和最大ID 
      DECLARE @FirstRec int, @LastRec int 
      SELECT @FirstRec = (@Page - 1) * @RecsPerPage 
      SELECT @LastRec = (@Page * @RecsPerPage + 1) 

      -- 得到實際 的記錄,并返回是否還有數據! 
      SELECT *, 
      MoreRecords = 

      SELECT COUNT(*) 
      FROM #TempItems TI 
      WHERE TI.ID >= @LastRec 

      FROM #TempItems 
      WHERE ID > @FirstRec AND ID < @LastRec

      -- 恢復設置
      SET NOCOUNT OFF

      在這個存儲過程里,我們首先創建一個全部 記錄的臨時表,并增加了一個自動編號的字段ID。這樣,不同的記錄就有
      一個遞增的唯一標志。
      根據當前的頁號和每頁的記錄數,可以計算 出每頁的最小和最大的ID。從而得到當前頁的所有記錄。
      為了顯示的方便,存儲過程還計算了 MoreRecords字段,作為顯示下一頁的判斷條件。
      利用了這個存儲過程的程序代碼如下:
      <%
      '每頁顯示10條
      Const iRecordsPerPage = 10

      Dim currentPage '當前頁號
      Dim bolLastPage '在最后一頁?

      if len(Request.QueryString("page")) = 0 then
      currentPage = 1
      else
      currentPage = CInt(Request.QueryString("page"))
      end if

      '得到當前頁的記錄
      strSQL = "sp_PagedItems " & currentPage & "," & iRecordsPerPage
      objRS.Open strSQL, objConn

      '判斷是否在最后一頁
      if Not objRS.EOF then
      if CInt(objRS("MoreRecords")) > 0 then 
      bolLastPage = False 
      else 
      bolLastPage = True 
      end if 
      end if 
      %> 
      <P> 

      <TABLE BORDER=0 CELLSPACING=1 CELLPADDING=4 ALIGN=CENTER> 
      <TR><TH COLSPAN=2 BGCOLOR=NAVY> 
      <FONT SIZE=+1 COLOR=WHITE> 
      List of Items 
       
      </TH></TR> 
      <%
      Do While Not objRS.EOF %> 
      <TR><TD ALIGN=LEFT BGCOLOR=GRAY> 
      <%=objRS("Name")%> 
      </TD><TD ALIGN=CENTER BGCOLOR=GRAY> 
      <%=FormatCurrency(objRS("Price"))%> 
      </TD></TR> 
      <% objRS.MoveNext
      Loop %> 
      </TABLE> 
      <P> 
      <CENTER> 
      <%

      '第一頁不 顯示“前一頁”
      if currentPage > 1 then %> 
      <INPUT TYPE=BUTTON VALUE="<< 前 <%=iMaxRecords%> 記錄 " 
      ONCLICK="document.location.href='thispage.asp?page=<%=currentPage-1%>'"> ; 
         
      <% end if

      '最后一頁 不顯示“后一頁”
      if Not bolLastPage then %> 
      <INPUT TYPE=BUTTON VALUE="后 <%=iMaxRecords%> 記錄 >>" 
      ONCLICK="document.location.href='thispage.asp?page=<%=currentPage+1%>'"> ; 
      <% end if %> 
      </CENTER>


      日韩精品一区二区三区高清