常用正則表達式大全!

来源:http://www.cnblogs.com/walldong/archive/2016/03/21/5300982.html
-Advertisement-
Play Games

常用正則表達式大全!(例如:匹配中文、匹配html) 匹配中文字元的正則表達式: [u4e00-u9fa5] 評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了 匹配雙位元組字元(包括漢字在內):[^x00-xff] 評註:可以用來計算字元串的長度(一個雙位元組字元長度計2,ASCII字元計1) 匹


常用正則表達式大全!(例如:匹配中文、匹配html) 

 匹配中文字元的正則表達式: [u4e00-u9fa5]     

評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了  

 匹配雙位元組字元(包括漢字在內):[^x00-xff]  

 評註:可以用來計算字元串的長度(一個雙位元組字元長度計2,ASCII字元計1)  

 匹配空白行的正則表達式:ns*r  

 評註:可以用來刪除空白行

 匹配HTML標記的正則表達式:<(S*?)[^>]*>.*?|<.*? />  

 評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於複雜的嵌套標記依舊無能為力  

 匹配首尾空白字元的正則表達式:^s*|s*$   

評註:可以用來刪除行首行尾的空白字元(包括空格、製表符、換頁符等等),非常有用的表達式   

匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*  

 評註:表單驗證時很實用

 匹配網址URL的正則表達式:[a-zA-z]+://[^s]*   

評註:網上流傳的版本功能很有限,上面這個基本可以滿足需求   

匹配帳號是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):

^[a-zA-Z][a-zA-Z0-9_]{4,15}$  

 評註:表單驗證時很實用   

匹配國內電話號碼:d{3}-d{8}|d{4}-d{7}  

 評註:匹配形式如 0511-4405222 或 021-87888822  

 匹配騰訊QQ號:[1-9][0-9]{4,}  

 評註:騰訊QQ號從10000開始  

 匹配中國郵政編碼:[1-9]d{5}(?!d)  

 評註:中國郵政編碼為6位數字

 

 匹配身份證:d{15}|d{18}  

 評註:中國的身份證為15位或18位

  匹配ip地址:d+.d+.d+.d+

  評註:提取ip地址時有用  

 匹配特定數字:   

^[1-9]d*$    //匹配正整數  

 ^-[1-9]d*$   //匹配負整數  

 ^-?[1-9]d*$   //匹配整數  

 ^[1-9]d*|0$  //匹配非負整數(正整數 + 0)  

 ^-[1-9]d*|0$   //匹配非正整數(負整數 + 0)  

 ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮點數  

 ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配負浮點數  

 ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮點數  

 ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非負浮點數(正浮點數 + 0)  

 ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮點數(負浮點數 + 0)

  評註:處理大量數據時有用,具體應用時註意修正

 匹配特定字元串:  

 ^[A-Za-z]+$  //匹配由26個英文字母組成的字元串   

^[A-Z]+$  //匹配由26個英文字母的大寫組成的字元串  

 ^[a-z]+$  //匹配由26個英文字母的小寫組成的字元串

 

 ^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字元串   

   ^w+$       //匹配由數字、26個英文字母或者下劃線組成的字元串  

 在使用RegularExpressionValidator驗證控制項時的驗證功能及其驗證表達式介紹如下:  

 只能輸入數字:“^[0-9]*$”  

 只能輸入n位的數字:“^d{n}$”  

 只能輸入至少n位數字:“^d{n,}$”  

 只能輸入m-n位的數字:“^d{m,n}$”  

 只能輸入零和非零開頭的數字:“^(0|[1-9][0-9]*)$”  

 只能輸入有兩位小數的正實數:“^[0-9]+(.[0-9]{2})?$”  

 只能輸入有1-3位小數的正實數:“^[0-9]+(.[0-9]{1,3})?$”  

 只能輸入非零的正整數:“^+?[1-9][0-9]*$”

 

只能輸入非零的負整數:“^-[1-9][0-9]*$”  

 只能輸入長度為3的字元:“^.{3}$”  

 只能輸入由26個英文字母組成的字元串:“^[A-Za-z]+$”  

 只能輸入由26個大寫英文字母組成的字元串:“^[A-Z]+$”  

 只能輸入由26個小寫英文字母組成的字元串:“^[a-z]+$”   

  只能輸入由數字和26個英文字母組成的字元串:“^[A-Za-z0-9]+$”  

 只能輸入由數字、26個英文字母或者下劃線組成的字元串:“^w+$”  

  驗證用戶密碼:“^[a-zA-Z]w{5,17}$”

正確格式為:以字母開頭,長度在6-18之間,只能包含字元、數字和下劃線。      

驗證是否含有^%&'',;=?$"等字元:“[^%&'',;=?$x22]+”  

 只能輸入漢字:“^[u4e00-u9fa5],{0,}$”  

 驗證Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”  

 驗證InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”   

   驗證電話號碼:“^((d{3,4})|d{3,4}-)?d{7,8}$”  

 正確格式為:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,   “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。   

驗證身份證號(15位或18位數字):“^d{15}|d{}18$”

 

驗證一年的12個月:“^(0?[1-9]|1[0-2])$”正確格式為:“01”-“09”和“1”“12”   

驗證一個月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”   

正確格式為:“01”“09”和“1”“31”。  

 匹配中文字元的正則表達式: [u4e00-u9fa5]  

 匹配雙位元組字元(包括漢字在內):[^x00-xff]   

匹配空行的正則表達式:n[s| ]*r  

 匹配HTML標記的正則表達式:/<(.*)>.*|<(.*) />/   

  匹配首尾空格的正則表達式:(^s*)|(s*$)

 

 匹配Email地址的正則表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

 匹配網址URL的正則表達式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

 

 (5)應用:利用正則表達式限制網頁表單里的文本框輸入內容  

 用正則表達式限制只能輸入中文:

onkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^u4E00-u9FA5]/g,''))"   

用正則表達式限制只能輸入全形字元: 

onkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^uFF00-uFFFF]/g,''))"   

用正則表達式限制只能輸入數字:

onkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste= "clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''))"   

用正則表達式限制只能輸入數字和英文:

onkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,'' 

 

用途:判斷是否是日期  輸入:date:日期;fmt:日期格式  返回:如果通過驗證返回true,否則返回false  */ function isDate( date, fmt ) { 

if (fmt==null) fmt="yyyyMMdd"; 

var yIndex = fmt.indexOf("yyyy"); 

if(yIndex==-1) 

return false; 

var year = date.substring(yIndex,yIndex+4); 

var mIndex = fmt.indexOf("MM"); 

if(mIndex==-1)

 return false; 

var month = date.substring(mIndex,mIndex+2); 

var dIndex = fmt.indexOf("dd"); 

if(dIndex==-1)

 return false; 

var day = date.substring(dIndex,dIndex+2); 

if(!isNumber(year)||year>"2100" || year< "1900") 

return false; 

if(!isNumber(month)||month>"12" || month< "01") 

return false;

  if(day>getMaxDay(year,month) || day< "01") 

return false; 

return true; 

function getMaxDay(year,month) { 

if(month==4||month==6||month==9||month==11)  return "30"; 

if(month==2)  i

f(year%4==0&&year%100!=0 || year%400==0) 

return "29"; 

else  return "28"; 

return "31"; 

摘自:http://www.cnblogs.com/shouce/p/5300513.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 運算 sass可進行簡單的加減乘除運算等 所謂選擇器嵌套指的是在一個選擇器中嵌套另一個選擇器來實現繼承,從而增強了sass文件的結構性和可讀性。 如上代碼,定義了兩個占位選擇器%ir和%clearfix,其中%clearfix這個沒有調用,所以解析出來的css樣式也就沒有clearfix部分。占位選
  • 屬性列表 說明 webkit webkit相關瀏覽器則返回true,否則返回false,如google,傲游。 mozilla mozilla相關瀏覽器則返回true,否則返回false,如火狐 safari safari相關瀏覽器則返回true,否則返回false,如safari opera op
  • 首先,React.js是facebook在2013年5月開源的一個前端框架,React不是一個MVC框架,它是構建易於可重覆調用的web組件,側重於UI, 也就是view層, React為了更高超的性能而使用虛擬DOM作為其不同的實現。 它同時也可以由服務端Node.js渲染 - 而不需要過重的瀏覽
  • 最近做重構,有一個功能是,滑鼠點擊鏈接後顯示不同樣式: 代碼如下,樣式佈局我修改後如下,使用bootstrap框架來做。 現在重點說一下:功能實現。 原來代碼是這樣實現鏈接點擊樣式的,給每個鏈接不同的class, 然後在page1.html頁面定義: 同理在page2.html頁面定義: 在page
  • Firebug功能異常強大,不僅可以調試DOM,CSS,還可以調試JS代碼,下麵介紹一下調試JS。 console對象是Firebug內置的對象,該對象可以在代碼中寫入,可以在控制面板中寫入。 1)有五個方法來顯示信息。依次為: 1、console.log(),可以用來取代alert()或docum
  • 之前計劃是一周還原一個網頁或者切一張psd來練習基本功的。正好周五的時候接到一個電話面試,讓我還原一下163郵箱主頁,晚上發給他,就正好當是這周的練習吧。 吃完晚飯開工,做到12點,差不多4個小時,基本上做完了,不過還有些局部沒完成。算還原度90%吧,剩下的這兩天有空再補啦。 這是目前的完成情況 w
  • 最近在學習NodeJS,用到了express,看著官網上的API手冊,打算把其中比較常用到的API根據自己理解翻譯一下,方便自己學習使用. 該篇打算用來記錄下express中res. 由於水平有限,希望能得到大家的修改,在學習過程中我會持續更新修改 Response res對象表示的是Express
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...