正則表達式實例

匹配雙字節字符(包括漢字在內)[^\x00-\xff]
  評註:能夠用來計算字符串的長度(一個雙字節字符長度計2ASCII字符計1
  匹配空白行的正則表達式:\n\s*\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個英文字母或者下劃線組成的字符串 html

驗證手機號碼和電話號碼的正則表達式 git

電話號碼正則表達式(支持手機號碼,3-4位區號,7-8位直播號碼,14位分機號) ((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$)

匹配格式:
11位手機號碼
3-4位區號,7-8位直播號碼,14位分機號
如:123456789011234-12345678-1234
"^\d+$"  //非負整數(正整數 + 0
"^[0-9]*[1-9][0-9]*$"  //正整數
"^((-\d+)|(0+))$"  //非正整數(負整數 + 0
"^-[0-9]*[1-9][0-9]*$"  //負整數
"^-?\d+$"    //整數
"^\d+(\.\d+)?$"  //非負浮點數(正浮點數 + 0
"^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮點數
"^((-\d+(\.\d+)?)|(0+(\.0+)?))$"  //非正浮點數(負浮點數 + 0
"^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //負浮點

"^(-?\d+)(\.\d+)?$"  //浮點數
"^[A-Za-z]+$"  //26個英文字母組成的字符串
"^[A-Z]+$"  //26個英文字母的大寫組成的字符串
"^[a-z]+$"  //26個英文字母的小寫組成的字符串
"^[A-Za-z0-9]+$"  //由數字和26個英文字母組成的字符串
"^\w+$"  //由數字、26個英文字母或者下劃線組成的字符串
"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email地址
"^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url
/^13\d{9}$/gi手機號正則表達式 正則表達式


public static bool IsValidMobileNo(string MobileNo)
 {
 const string regPattern = @"^(130|131|132|133|134|135|136|137|138|139)\d{8}$";
 return Regex.IsMatch(MobileNo, regPattern);
 } sql


正則表達式--驗證手機號碼:13[0-9]{9}
實現手機號前帶86或是+86的狀況:^((\+86)|(86))?(13)\d{9}$
電話號碼與手機號碼同時驗證:(^(\d{3,4}-)?\d{7,8})$|(13[0-9]{9})
提取信息中的網絡連接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
提取信息中的郵件地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
提取信息中的圖片連接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
提取信息中的IP地址:(\d+)\.(\d+)\.(\d+)\.(\d+)
提取信息中的中國手機號碼:(86)*0*13\d{9}
提取信息中的中國固定電話號碼:(\(\d{3,4}\)|\d{3,4}-|\s)?\d{8}
提取信息中的中國電話號碼(包括移動和固定電話):(\(\d{3,4}\)|\d{3,4}-|\s)?\d{7,14}
提取信息中的中國郵政編碼:[1-9]{1}(\d+){5}
提取信息中的中國身份證號碼:\d{18}|\d{15}
提取信息中的整數:\d+
提取信息中的浮點數(即小數):(-?\d*)\.?\d+
提取信息中的任何數字 :(-?\d*)(\.\d+)?
提取信息中的中文字符串:[\u4e00-\u9fa5]*
提取信息中的雙字節字符串 (漢字)[^\x00-\xff]* 網絡

需求: 編碼

匹配手機號,第一位能夠是+,能夠沒有+,後面的所有要是數字,如: url

+861359415665 spa

8613659558555 .net

1356856455 regexp

都是合法的。

+aa156945555

aa1359556666

aaddssdfdfsd

都是不合法的。

正則:

[sql]view plaincopyprint?

SQL>SELECT *FROM DUALWHERE regexp_like('+333333' ,'^[\+]*[[:digit:]]+');--+轉義或者不轉義,結果是同樣的 

DUMMY

----- 

X


[sql]view plaincopyprint?

SQL>SELECT *FROM DUALWHERE regexp_like('aa333333' ,'^[+]*[[:digit:]]+');

DUMMY

----- 


解釋:

1.^表明開始,*表示出現0次或屢次,+表示出現1次或屢次,[:digit:]表明0-9的純數字(還有$表明以什麼結尾,若是是[[:digit:]]+$表明以數字結尾)。該正則的意思就是:

+0次或屢次開頭,緊接着後面數字出現一次或屢次(即必定要有數字)。

2.dual表中,永遠只有1行記錄。查詢出dual中有記錄,證實where條件成立,反之不成立。

先前寫了一個錯誤的正則:

[sql]view plaincopyprint?

10 [\+]*[[:digit:]]+

注意,就只少了一個表明開始符號的^。少了這個符號,說明這個正則的意思是:

+出現0次或屢次(即+能夠出現,能夠不出現!!),緊後面的數字出現1次或屢次。前面已經+能夠出現0次了,證實沒有+也能夠,那麼就是隻要字符串中有數字(+aa111aaass11111……),這個正則恆成立,錯誤深重啊!!

相關文章
相關標籤/搜索