- 浏览: 259456 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
jeans_1312:
...
JAVA检测字符串编码并转换 -
zenzuguo:
为啥我在eclipse tomcat6.0启动时总报错
Ma ...
appfuse2.0.2在eclipse下的开发和使用 -
josewu2009:
楼主我用你的方法在window机器 上 压缩后 ,解压文件时报 ...
java压缩文件夹下的所有文件和选定文件及乱码解决 -
TonyLian:
我觉得2楼提出的,只不过是看起来更漂亮而已,原写法也不会出现B ...
Ibatis动态查询例子(#和$以及iterate等的用法) -
zhaoshg:
谢谢 lemonweirui 的更正,帮我发现了一个bug,谢 ...
Ibatis动态查询例子(#和$以及iterate等的用法)
- /*************************************************
- Validator v1.03
- code by 我佛山人
- wfsr@msn.com
- *************************************************/
- Validator = {
- Require : /.+/,
- Email : /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,
- Phone : /^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/,
- Mobile : /^((\(\d{3}\))|(\d{3}\-))?13\d{9}$/,
- Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\" ])*$/,
- IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/,
- Currency : /^\d+(\.\d+)?$/,
- Number : /^\d+$/,
- Zip : /^[1-9]\d{5}$/,
- QQ : /^[1-9]\d{4,8}$/,
- Integer : /^[-\+]?\d+$/,
- Double : /^[-\+]?\d+(\.\d+)?$/,
- English : /^[A-Za-z]+$/,
- Chinese : /^[\u0391-\uFFE5]+$/,
- Username : /^[a-z]\w{3,}$/i,
- UnSafe : /^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/,
- IsSafe : function (str){ return ! this .UnSafe.test(str);},
- SafeString : "this.IsSafe(value)" ,
- Limit : "this.limit(value.length,getAttribute('min'), getAttribute('max'))" ,
- LimitB : "this.limit(this.LenB(value), getAttribute('min'), getAttribute('max'))" ,
- Date : "this.IsDate(value, getAttribute('min'), getAttribute('format'))" ,
- Repeat : "value == document.getElementsByName(getAttribute('to'))[0].value" ,
- Range : "getAttribute('min') < (value|0) && (value|0) < getAttribute('max')" ,
- Compare : "this.compare(value,getAttribute('operator'),getAttribute('to'))" ,
- Custom : "this.Exec(value, getAttribute('regexp'))" ,
- Group : "this.MustChecked(getAttribute('name'), getAttribute('min'), getAttribute('max'))" ,
- ErrorItem : [document.forms[0]],
- ErrorMessage : ["以下原因导致提交失败:\t\t\t\t" ],
- Validate : function (theForm, mode){
- var ōbj = theForm || event.srcElement;
- var count = obj.elements.length;
- this .ErrorMessage.length = 1;
- this .ErrorItem.length = 1;
- this .ErrorItem[0] = obj;
- for ( var i=0;i
- with (obj.elements[i]){
- var _dataType = getAttribute( "dataType" );
- if ( typeof (_dataType) == "object" || typeof ( this [_dataType]) == "undefined" ) continue ;
- this .ClearState(obj.elements[i]);
- if (getAttribute( "require" ) == "false" && value == "" ) continue ;
- switch (_dataType){
- case "Date" :
- case "Repeat" :
- case "Range" :
- case "Compare" :
- case "Custom" :
- case "Group" :
- case "Limit" :
- case "LimitB" :
- case "SafeString" :
- if (!eval( this [_dataType])) {
- this .AddError(i, getAttribute( "msg" ));
- }
- break ;
- default :
- if (! this [_dataType].test(value)){
- this .AddError(i, getAttribute( "msg" ));
- }
- break ;
- }
- }
- }
- if ( this .ErrorMessage.length > 1){
- mode = mode || 1;
- var errCount = this .ErrorItem.length;
- switch (mode){
- case 2 :
- for ( var i=1;i
- this .ErrorItem[i].style.color = "red" ;
- case 1 :
- alert(this .ErrorMessage.join( "\n" ));
- this .ErrorItem[1].focus();
- break ;
- case 3 :
- for ( var i=1;i
- try {
- var span = document.createElement( "SPAN" );
- span.id = "__ErrorMessagePanel" ;
- span.style.color = "red" ;
- this .ErrorItem[i].parentNode.appendChild(span);
- span.innerHTML = this .ErrorMessage[i].replace(/\d+:/, "*" );
- }
- catch (e){alert(e.descrīption);}
- }
- this .ErrorItem[1].focus();
- break ;
- default :
- alert(this .ErrorMessage.join( "\n" ));
- break ;
- }
- return false ;
- }
- return true ;
- },
- limit : function (len,min, max){
- min = min || 0;
- max = max || Number.MAX_VALUE;
- return min <= len && len <= max;
- },
- LenB : function (str){
- return str.replace(/[^\x00-\xff]/g, "**" ).length;
- },
- ClearState : function (elem){
- with (elem){
- if (style.color == "red" )
- style.color = "" ;
- var lastNode = parentNode.childNodes[parentNode.childNodes.length-1];
- if (lastNode.id == "__ErrorMessagePanel" )
- parentNode.removeChild(lastNode);
- }
- },
- AddError : function (index, str){
- this .ErrorItem[ this .ErrorItem.length] = this .ErrorItem[0].elements[index];
- this .ErrorMessage[ this .ErrorMessage.length] = this .ErrorMessage.length + ":" + str;
- },
- Exec : function (op, reg){
- return new RegExp(reg, "g" ).test(op);
- },
- compare : function (op1,operator,op2){
- switch (operator) {
- case "NotEqual" :
- return (op1 != op2);
- case "GreaterThan" :
- return (op1 > op2);
- case "GreaterThanEqual" :
- return (op1 >= op2);
- case "LessThan" :
- return (op1 < op2);
- case "LessThanEqual" :
- return (op1 <= op2);
- default :
- return (op1 == op2);
- }
- },
- MustChecked : function (name, min, max){
- var groups = document.getElementsByName(name);
- var hasChecked = 0;
- min = min || 1;
- max = max || groups.length;
- for ( var i=groups.length-1;i>=0;i--)
- if (groups[i].checked) hasChecked++;
- return min <= hasChecked && hasChecked <= max;
- },
- IsDate : function (op, formatString){
- formatString = formatString || "ymd" ;
- var m, year, month, day;
- switch (formatString){
- case "ymd" :
- m = op.match(new RegExp( "^((\\d{4})|(\\d{2}))([-./])(\\d{1,2})\\4(\\d{1,2})$" ));
- if (m == null ) return false ;
- day = m[6];
- month = m[5]*1;
- year = (m[2].length == 4) ? m[2] : GetFullYear(parseInt(m[3], 10));
- break ;
- case "dmy" :
- m = op.match(new RegExp( "^(\\d{1,2})([-./])(\\d{1,2})\\2((\\d{4})|(\\d{2}))$" ));
- if (m == null ) return false ;
- day = m[1];
- month = m[3]*1;
- year = (m[5].length == 4) ? m[5] : GetFullYear(parseInt(m[6], 10));
- break ;
- default :
- break ;
- }
- if (!parseInt(month)) return false ;
- month = month==0 ?12:month;
- var date = new Date(year, month-1, day);
- return ( typeof (date) == "object" && year == date.getFullYear() && month == (date.getMonth()+1) && day == date.getDate());
- function GetFullYear(y){ return ((y<30 ? "20" : "19" ) + y)|0;}
- }
- }
/************************************************* Validator v1.03 code by 我佛山人 wfsr@msn.com *************************************************/ Validator = { Require : /.+/, Email : /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/, Phone : /^((\(\d{3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$/, Mobile : /^((\(\d{3}\))|(\d{3}\-))?13\d{9}$/, Url : /^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$/, IdCard : /^\d{15}(\d{2}[A-Za-z0-9])?$/, Currency : /^\d+(\.\d+)?$/, Number : /^\d+$/, Zip : /^[1-9]\d{5}$/, QQ : /^[1-9]\d{4,8}$/, Integer : /^[-\+]?\d+$/, Double : /^[-\+]?\d+(\.\d+)?$/, English : /^[A-Za-z]+$/, Chinese : /^[\u0391-\uFFE5]+$/, Username : /^[a-z]\w{3,}$/i, UnSafe : /^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/, IsSafe : function(str){return !this.UnSafe.test(str);}, SafeString : "this.IsSafe(value)", Limit : "this.limit(value.length,getAttribute('min'), getAttribute('max'))", LimitB : "this.limit(this.LenB(value), getAttribute('min'), getAttribute('max'))", Date : "this.IsDate(value, getAttribute('min'), getAttribute('format'))", Repeat : "value == document.getElementsByName(getAttribute('to'))[0].value", Range : "getAttribute('min') < (value|0) && (value|0) < getAttribute('max')", Compare : "this.compare(value,getAttribute('operator'),getAttribute('to'))", Custom : "this.Exec(value, getAttribute('regexp'))", Group : "this.MustChecked(getAttribute('name'), getAttribute('min'), getAttribute('max'))", ErrorItem : [document.forms[0]], ErrorMessage : ["以下原因导致提交失败:\t\t\t\t"], Validate : function(theForm, mode){ var ōbj = theForm || event.srcElement; var count = obj.elements.length; this.ErrorMessage.length = 1; this.ErrorItem.length = 1; this.ErrorItem[0] = obj; for(var i=0;i with(obj.elements[i]){ var _dataType = getAttribute("dataType"); if(typeof(_dataType) == "object" || typeof(this[_dataType]) == "undefined") continue; this.ClearState(obj.elements[i]); if(getAttribute("require") == "false" && value == "") continue; switch(_dataType){ case "Date" : case "Repeat" : case "Range" : case "Compare" : case "Custom" : case "Group" : case "Limit" : case "LimitB" : case "SafeString" : if(!eval(this[_dataType])) { this.AddError(i, getAttribute("msg")); } break; default : if(!this[_dataType].test(value)){ this.AddError(i, getAttribute("msg")); } break; } } } if(this.ErrorMessage.length > 1){ mode = mode || 1; var errCount = this.ErrorItem.length; switch(mode){ case 2 : for(var i=1;i this.ErrorItem[i].style.color = "red"; case 1 : alert(this.ErrorMessage.join("\n")); this.ErrorItem[1].focus(); break; case 3 : for(var i=1;i try{ var span = document.createElement("SPAN"); span.id = "__ErrorMessagePanel"; span.style.color = "red"; this.ErrorItem[i].parentNode.appendChild(span); span.innerHTML = this.ErrorMessage[i].replace(/\d+:/,"*"); } catch(e){alert(e.descrīption);} } this.ErrorItem[1].focus(); break; default : alert(this.ErrorMessage.join("\n")); break; } return false; } return true; }, limit : function(len,min, max){ min = min || 0; max = max || Number.MAX_VALUE; return min <= len && len <= max; }, LenB : function(str){ return str.replace(/[^\x00-\xff]/g,"**").length; }, ClearState : function(elem){ with(elem){ if(style.color == "red") style.color = ""; var lastNode = parentNode.childNodes[parentNode.childNodes.length-1]; if(lastNode.id == "__ErrorMessagePanel") parentNode.removeChild(lastNode); } }, AddError : function(index, str){ this.ErrorItem[this.ErrorItem.length] = this.ErrorItem[0].elements[index]; this.ErrorMessage[this.ErrorMessage.length] = this.ErrorMessage.length + ":" + str; }, Exec : function(op, reg){ return new RegExp(reg,"g").test(op); }, compare : function(op1,operator,op2){ switch (operator) { case "NotEqual": return (op1 != op2); case "GreaterThan": return (op1 > op2); case "GreaterThanEqual": return (op1 >= op2); case "LessThan": return (op1 < op2); case "LessThanEqual": return (op1 <= op2); default: return (op1 == op2); } }, MustChecked : function(name, min, max){ var groups = document.getElementsByName(name); var hasChecked = 0; min = min || 1; max = max || groups.length; for(var i=groups.length-1;i>=0;i--) if(groups[i].checked) hasChecked++; return min <= hasChecked && hasChecked <= max; }, IsDate : function(op, formatString){ formatString = formatString || "ymd"; var m, year, month, day; switch(formatString){ case "ymd" : m = op.match(new RegExp("^((\\d{4})|(\\d{2}))([-./])(\\d{1,2})\\4(\\d{1,2})$")); if(m == null ) return false; day = m[6]; month = m[5]*1; year = (m[2].length == 4) ? m[2] : GetFullYear(parseInt(m[3], 10)); break; case "dmy" : m = op.match(new RegExp("^(\\d{1,2})([-./])(\\d{1,2})\\2((\\d{4})|(\\d{2}))$")); if(m == null ) return false; day = m[1]; month = m[3]*1; year = (m[5].length == 4) ? m[5] : GetFullYear(parseInt(m[6], 10)); break; default : break; } if(!parseInt(month)) return false; month = month==0 ?12:month; var date = new Date(year, month-1, day); return (typeof(date) == "object" && year == date.getFullYear() && month == (date.getMonth()+1) && day == date.getDate()); function GetFullYear(y){return ((y<30 ? "20" : "19") + y)|0;} } }
使用:
语法
:dataType
="Require
| Chinese
| English
| Number
| Integer
| Double
| Email
| Url
| Phone
| Mobile
| Currency
| Zip
| IdCard
| QQ
| Date
| SafeString
| Repeat
| Compare
| Range
| Limit
| LimitB
| Group
| Custom
" |
类型 :字符串 。必选。 |
说明 :用于设定表单项的输入数据验证类型。 |
选值说明 : |
可选值 | 验证功能 |
Require | 必填项 |
Chinese | 中文 |
English | 英文 |
Number |
数字 |
Integer
|
整数 |
Double
|
实数 |
Email
|
Email地址格式 |
Url
|
基于HTTP协议的网址格式 |
Phone
|
电话号码格式 |
Mobile
|
手机号码格式 |
Currency
|
货币格式 |
Zip
|
邮政编码 |
IdCard
|
身份证号码 |
QQ
|
QQ号码 |
Date
|
日期 |
SafeString
|
安全密码 |
Repeat
|
重复输入 |
Compare
|
关系比较 |
Range
|
输入范围 |
Limit
|
限制输入长度 |
LimitB
|
限制输入的字节长度 |
Group | 验证单/多选按钮组 |
Custom | 自定义正则表达式 验证 |
语法 :max ="int " |
类型 :字符串。在dataType 属性值为Range 时必选,为Group 且待验证项是多选按钮组时可选(此时默认值为1 ),为为Limit/LimitB 时可选(此时默认值为1.7976931348623157e+308 ,即Number .MAX_VALUE 的值)。 |
说明 :当daType 属性值为Range 时,用于判断输入是否在min 与max 的属性值间;当dataType 属性值为Group ,且待验证项是多选按钮组时,用于设定多选按钮组的选中个数,判断选中个数是否在[min , max ]区间;当daType 属性值为Limit 时,用于验证输入的字符数是否在[min , max ]区间;当daType 属性值为LimitB 时,用于验证输入字符的字节数是否在[min , max ]区间。 |
语法 :min ="int " |
类型 :字符串。在dataType 属性值为Range 时必选,为Group 且待验证项是多选按钮组时可选(此时默认值为1 ),为为Limit/LimitB 时可选(此时默认值为0)。 |
说明 :当daType 属性值为Range 时,用于判断输入是否在min 与max 的属性值间;当dataType 属性值为Group ,且待验证项是多选按钮组时,用于设定多选按钮组的选中个数,判断选中个数是否在[min , max ]区间;当daType 属性值为Limit 时,用于验证输入的字符数是否在[min , max ]区间;当daType 属性值为LimitB 时,用于验证输入字符的字节数是否在[min , max ]区间。 |
语法 : msg ="string " |
类型 :字符串。必选。 |
说明 :在验证失败时要提示的出错信息。 |
语法 :operator ="NotEqual | GreaterThan | GreaterThanEqual | LessThan | LessThanEqual | Equal " | ||||||||||||||
类型 :字符串。在dataType 属性值为Compare 时可选(默认值为Equal )。 | ||||||||||||||
说明
:参考to
属性。 各选值所对应的关系操作符 :
|
语法 :require ="true | false " |
类型 :字符串。可选。 |
说明 :用于设定表单项的验证方式。当值为false 时表单项不是必填项,但当有填写时,仍然要执行dataType 属性所设定的验证方法,值为true 或任何非false 字符时可省略此属性。 |
语法 :to ="sting | int " |
类型 :字符串。当dataType 值为Repeat 或Compare 时必选。 |
说明 :当dataType 值为Repeat 时,to 的值为某表单项的name 属性值,用于设定当前表单项的值是否与目标表单项的值一致;当dataType 的值为Compare 时,to 的选值类型为实数,用于判断当前表单项的输入与to 的值是否符合operator 属性值所指定的关系。 |
语法 :format ="ymd | dmy " |
类型 :字符串。在dataType 属性值为Date 时可选(默认值为ymd )。 |
说明
:用于验证输入是否为符合format
属性值所指定格式的日期。 符合规则的输入示例 : 2004-11-23 ,2004/11/23 ,04.11.23 ,23-11-2004 等 注意 :当输入的年份为2 位时,如果数值小于30 ,将使年份看作处于21 世纪,否则为20 世纪。 |
语法 :regexp ="object " |
类型 :字符串。在dataType 属性值为Custom时必选。 |
说明 :用于验证输入是否符合regexp 属性所指定的正则表达式。 |
元字符:
/b 代表着单词的开头或结尾,也就是单词的分界处.如果要精确地查找hi这个单词的话,我们应该使用/bhi/b.
.是另一个元字符,匹配除了换行符以外的任意字符,*同样是元字符,它指定*前边的内容可以重复任意次以使整个表达式得到匹配。
.*连在一起就意味着任意数量的不包含换行的字符。
/d是一个新的元字符,匹配任意的数字,0/d/d-/d/d/d/d/d/d/d/d也就是中国的电话号码.为了避免那么多烦人的重复,我们也可以这样写这个表达式:0/d{2}-/d{8}。
/s匹配任意的空白符,包括空格,制表符(Tab),换行符,中文全角空格等。/w匹配字母或数字或下划线或汉字。
/b/w{6}/b 匹配刚好6个字母/数字的单词。
字符转义:使用/来取消这些字符的特殊意义。因此,你应该使用/.和/*。当然,要查找/本身,你也得用//。
代码 说明
. 匹配除换行符以外的任意字符
/w 匹配字母或数字或下划线或汉字
/s 匹配任意的空白符
/d 匹配数字
/b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束
重复:
常用的限定符
代码/语法 说明
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次
要想查找数字,字母或数字,你只需要在中括号里列出它们就行了,像[aeiou]就匹配任何一个元音字母,[.?!]匹配标点符号(.或?或!)
反义:
常用的反义代码
代码/语法 说明
/W 匹配任意不是字母,数字,下划线,汉字的字符
/S 匹配任意不是空白符的字符
/D 匹配任意非数字的字符
/B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符
替换:
正则表达式里的替换指的是有几种规则,如果满足其中任意一种规则都应该当成匹配,具体方法是用|把不同的规则分隔开。
0/d{2}-/d{8}|0/d{3}-/d{7}这个表达式能匹配两种以连字号分隔的电话号码:一种是三位区号,8位本地号(如010-12345678),一种是4位区号,7位本地号(0376-2233445)。
/(0
/d{2}/)[- ]?/d{8}|0/d{2}[- ]?/d{8}这个表达式匹配3位区号的电话号码,其中区号可以用小括号括起来,也可以不用,区
号与本地号间可以用连字号或空格间隔,也可以没有间隔。你可以试试用替换|把这个表达式扩展成也支持4位区号的。
/d{5}-/d{4}|
/d{5}这个表达式用于匹配美国的邮政编码。美国邮编的规则是5位数字,或者用连字号间隔的9位数字。之所以要给出这个例子是因为它能说明一个问题:使
用替换时,顺序是很重要的。如果你把它改成/d{5}|/d{5}-/d{4}的话,那么就只会匹配5位的邮编(以及9位邮编的前5位)。原因是匹配替换
时,将会从左到右地测试每个分枝条件,如果满足了某个分枝的话,就不会去管其它的替换条件了。
分组:
如果想要重复一个字符串又该怎么办?你可以用小括号来指定子表达式(也叫做分组),然后你就可以指定这个子表达式的重复次数了。
(/d{1,3}
/.){3}/d{1,3}是一个简单的IP地址匹配表达式。要理解这个表达式,请按下列顺序分析它:/d{1,3}匹配1到3位的数字,(/d{1,3}/.}{3}匹配三位数字加上一个英文句号(这个整体也就是这个分组)重复3次,最后再加上一
个一到三位的数字(/d{1,3})。不幸的是,它也将匹配256.300.888.999这种不可能存在的IP地址(IP地址中每个数字都不能大于
255)。如果能使用算术比较的话,或许能简单地解决这个问题,但是正则表达式中并不提供关于数学的任何功能,所以只能使用冗长的分组,选择,字符类来描
述一个正确的IP地址:((2[0-4] /d|25[0-5]|[01]?/d/d?)/.){3}(2[0-4]/d|25[0-5]|[01]?
/d/d?)。
后向引用:
后向引用用于重复搜索前面某个分组匹配的文本。例如,/1代表分组1匹配的文本。难以理解?请看示例:
/b(/w+)/b/s+/1/b可以用来匹配重复的单词,像go go, kitty kitty。首先是一个单词,也就是单词开始处和结束处之间的多于一个的字母或数字(/b(/w+)/b),然后是1个或几个空白符(/s+,最后是前面匹配的那个单词(/1)。
懒惰限定符
*? 重复任意次,但尽可能少重复
+? 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复
位置指定:
接下来的四个用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们用于指定一个位置,就像/b,^,$那样,因此它们也被称为零宽断言。最好还是拿例子来说明吧:
(?=exp)
也叫零宽先行断言,它匹配文本中的某些位置,这些位置的后面能匹配给定的后缀exp。比如/b/w+(?=ing/b),匹配以 ing结尾的单词的前面
部分(除了ing以外的部分),如果在查找I'm singing while you're dancing.时,它会匹配sing和danc。
(?<=exp)也叫零宽后行断言,它匹配文本中的某些位置,这些位置的前面能给定的前缀匹配exp。比如(?<=/bre)/w+/b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找reading a book时,它匹配ading。
假如你想要给一个很长的数字中每三位间加一个逗号(当然是从右边加起了),你可以这样查找需要在前面和里面添加逗号的部分:((?<=/d)/d{3})*/b。请仔细分析这个表达式,它可能不像你第一眼看出来的那么简单。
下面这个例子同时使用了前缀和后缀:(?<=/s)/d+(?=/s)匹配以空白符间隔的数字(再次强调,不包括这些空白符)。
负向位置指定:
前面我们提到过怎么查找不是某个字符或不在某个字符类里的字符的方法(反义)。但是如果我们只是想要确保某个字符没有出现,但并不想去匹配它时怎么办?例如,如果我们想查找这样的单词--它里面出现了字母q,但是q后面跟的不是字母u,我们可以尝试这样:
/b
/w*q[^u]/w*/b匹配包含后面不是字母u的字母q的单词。但是如果多做测试(或者你思维足够敏锐,直接就观察出来了),你会发现,如果q出现在
单词的结尾的话,像Iraq,Benq,这个表达式就会出错。这是因为[^u]总是匹配一个字符,所以如果q是单词的最后一个字符的话,后面的 [^u]
将会匹配q后面的单词分隔符(可能是空格,或者是句号或其它的什么),后面的/w+/b将会匹配下一个单词,于是/b/w*q[^u]/w*/b 就能匹
配整个Iraq fighting。负向位置指定能解决这样的问题,因为它只匹配一个位置,并不消费任何字符。现在,我们可以这样来解决这个问题:/b
/w*q(?!u) /w*/b。
零宽负向先行断言(?!exp),只会匹配后缀exp不存在的位置。/d{3}(?!/d)匹配三位数字,而且这三位数字的后面不能是数字。
同理,我们可以用(?<!exp),零宽负向后行断言来查找前缀exp不存在的位置:(?<![a-z])/d{7}匹配前面不是小写字母的七位数字(实验时发现错误?注意你的“区分大小写”先项是否选中)。
一
个更复杂的例子:(?<=<(/w+)>).*(?=<///1>)匹配不包含属性的简单HTML标签内里的内容。(&
lt;?(/w+)>)指定了这样的前缀:被尖括号括起来的单词(比如可能是<b>),然后是.*(任意的字符串),最后是一个后缀
(?=<///1>)。注意后缀里的//,它用到了前面提过的字符转义;/1则是一个反向引用,引用的正是捕获的第一组,前面的(/w +)
匹配的内容,这样如果前缀实际上是<b>的话,后缀就是</b>了。整个表达式匹配的是<b>
和< /b>之间的内容(再次提醒,不包括前缀和后缀本身)。
注释:
小括号的另一种用途是能过语法(?#comment)来包含注释。例如:2[0-4]/d(?#200-249)|25[0-5](?#250-255)|[01]?/d/d?(?#0-199)。
要包含注释的话,最好是启用“忽略模式里的空白符”选项,这样在编写表达式时能任意的添加空格,Tab,换行,而实际使用时这些都将被忽略。启用这个选项后,在#后面到这一行结束的所有文本都将被当成注释忽略掉。
例如,我们可以前面的一个表达式写成这样:
(?<= # 查找前缀,但不包含它
<(/w+)> # 查找尖括号括起来的字母或数字(标签)
) # 前缀结束
.* # 匹配任意文本
(?= # 查找后缀,但不包含它
<///1> # 查找尖括号括起来的内容:前面是一个"/",后面是先前捕获的标签
) # 后缀结束
贪婪与懒惰:
当
正则表达式中包含能接受重复的限定符(指定数量的代码,例如*, {5,12}等)时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的
字符。考虑这个表达式:a.*b,它将会匹配最长的以a开始,以b 结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称
为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab和ab(为什么第一个匹配是aab而不是ab?简单地说,最先开始的区配最有最大的优先权??The Match That Begins Earliest Wins)。
表5.懒惰限定符 *? 重复任意次,但尽可能少重复
+? 重复1次或更多次,但尽可能少重复
?? 重复0次或1次,但尽可能少重复
{n,m}? 重复n到m次,但尽可能少重复
{n,}? 重复n次以上,但尽可能少重复
-------------------------------------------------------
下面是一些常用的正则表达式:
匹配中文字符的正则表达式: [/u4e00-/u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了
匹配双字节字符(包括汉字在内):[^/x00-/xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
匹配空白行的正则表达式:/n/s*/r
评注:可以用来删除空白行
匹配HTML标记的正则表达式:<(/S*?)[^>]*>.*?<//1>|<.*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力
匹配首尾空白字符的正则表达式:^/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*$ //匹配正整数
相关推荐
JavaScript 正则表达式迷你书 本书是 JavaScript 正则表达式的入门级教程,旨在帮助读者快速掌握正则表达式的基本概念和应用。下面是本书的知识点摘要: 第一章:正则表达式字符匹配攻略 * 两种模糊匹配:横向...
javascript常用正则表达式大全,基本覆盖基本需求的正则表达式
以下是一些常见的JavaScript正则表达式及其应用: 1. **匹配中文字符**:`[\u4e00-\u9fa5]` 这个正则表达式用于匹配Unicode范围内的中文字符,包括所有汉字。例如,如果你想在一个字符串中查找所有中文字符,可以...
在IT领域,正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它能够进行复杂的模式匹配、查找、替换等操作。在本话题中,我们将探讨如何使用PowerBuilder 11.5这一经典的开发环境来实现正则...
以下是一些常见的正则表达式及其用途: 1. 匹配中文字符:`[u4e00-u9fa5]` - 这个正则表达式用于匹配所有中文字符,包括简体和繁体。它基于Unicode范围,u4e00到u9fa5涵盖了大部分常用汉字。 2. 匹配双字节字符:`...
正则表达式语法 正则表达式是一个强大的字符串处理工具,广泛应用于窗体验证、文本处理等领域。下面是正则表达式语法的详细介绍: 1. 元字符 元字符是正则表达式的特殊字符,它们具有特殊的含义。常见的元字符...
### 正则表达式在JavaScript中的应用:限制文本框只能输入数字及小数点 在Web开发中,经常需要对用户输入的数据进行合法性验证。为了确保数据格式正确且符合预期,开发者通常会在前端使用JavaScript结合HTML来实现...
常用正则表达式-常用正则表达式-常用正则表达式 常用正则表达式-常用正则表达式-常用正则表达式
正则表达式(Regular Expression,简称regex)是一种强大的文本处理工具,它用于匹配、查找、替换等操作,涉及字符串处理的各个领域。正则表达式转换工具是专门针对这一需求而设计的,它能帮助用户将输入的内容转换...
在本案例中,我们关注的是使用jQuery(jq)进行非空验证,以及使用JavaScript(js)的正则表达式来验证邮箱和手机号码的正确性。以下是关于这些知识点的详细说明: 1. **jQuery(jq)非空验证**: jQuery是一种轻...
主要为大家分享了最全的常用正则表达式大全,包括校验数字、字符、一些特殊的需求等等,感兴趣的小伙伴们可以参考一下。 很多不太懂正则的朋友,在遇到需要用正则校验数据时,往往是在网上去找很久,结果找来的还是...
标题中的“pb 使用正则表达式源码pbregexp”指的是在PowerBuilder(简称pb)环境中,利用名为“pbregexp”的正则表达式组件来实现源代码级别的正则表达式操作。PowerBuilder是一款流行的可视化的、面向对象的软件...
《JavaScript正则表达式迷你书》是一本关于JavaScript正则表达式的专业书籍,正则表达式是处理字符串的强大工具,广泛应用于编程语言中的文本处理。本书从字符匹配、位置匹配、括号的作用、回溯法原理、拆分、构建和...
js正则表达式,按甲方(银行)提供的个人证件信息采集规则编写的对应正则表达式
正则表达式是一种强大的文本处理工具,用于在字符串中进行模式匹配和搜索。在C#编程语言中,正则表达式被广泛应用于数据验证、文本提取、格式转换等多个场景。本项目提供了一个C#编写的正则表达式测试工具,包含完整...
正则表达式类库则为VC++和MFC的开发者提供了对正则表达式功能的支持。 "VC、VC++,MFC 正则表达式类库"指的是在MFC中实现或集成的正则表达式处理模块。这个库通常包含一系列的类和函数,允许程序员编写符合特定模式...
在正则表达式中,还有一些特定的元字符,例如数字字符(\d)、非数字字符(\D)、数字、字母或下划线(\w)、非数字、字母或下划线(\W)、空白字符(\s)、非空白字符(\S)等。这些元字符可以用于匹配特定的字符或...
常用验证正则表达式,手机号验证,身份证号验证,邮箱验证,等等,
正则表达式是指一个模式串,它由一些特殊的符号和字符组成,用于描述一个字符串的模式。Java中提供了对正则表达式的支持,使得开发者可以使用正则表达式来匹配和提取字符串中的内容。 二、XML节点内容提取方法 在...