今天要寫一個正則表達式,來做前端校驗。主要部分是 用來匹配1~4095的數字。
現在就以這個為例,說一下表示范圍的正則怎么寫。
1、只有1~3位數字,即數字范圍:1~999。
分析:第1個數字是1~9,后面的可以出現0~9的數字,最多2位。於是,就有了下面的字符串:
"[1-9]\\d{0,2}+"
2、4位數的,要小於等於4095,即數字范圍:1000~4095。
分析:第1位,可以是1~4;第2位,依賴第1位,當第1位是4的時候,第2位只能是0;同理,第3位依賴第2位;第4位依賴第3位。所以,就有了以下代碼:
"[1-4]\\d(?<!4[1-9])\\d\\d(?<!409[6-9])"
這里用的是非捕獲(?<!X) X,通過零寬度的負 lookbehind 來實現的。
附C#代碼郵編驗證示例:
//
10301-10314,10001-10292,/11200-11255,/10451-10499,11001-11697
Regex r = new Regex( @" 103[0-1]\d(?<!10300|1031[5-9])|10[0-2][0-9]\d(?<!10000|1029[3-9])|112[0-5]\d(?<!1125[6-9])|104[5-9]\d(?<!10450)|11[0-6][0-9]\d(?<!11000|1169[8-9]) ");
if (r.Matches(txtPostalCode.Text).Count> 0)
{
result = true;
BLL.Utility.ShowWarningBox( " 此郵編 [ " + txtPostalCode.Text + " ] 暫停收貨! ");
}
Regex r = new Regex( @" 103[0-1]\d(?<!10300|1031[5-9])|10[0-2][0-9]\d(?<!10000|1029[3-9])|112[0-5]\d(?<!1125[6-9])|104[5-9]\d(?<!10450)|11[0-6][0-9]\d(?<!11000|1169[8-9]) ");
if (r.Matches(txtPostalCode.Text).Count> 0)
{
result = true;
BLL.Utility.ShowWarningBox( " 此郵編 [ " + txtPostalCode.Text + " ] 暫停收貨! ");
}