正则表达式

最好的解释:微软公司 http://msdn.microsoft.com/library/chs/default.asp?url=/library/CHS/jscript7/html/jsreconintroductiontoregularexpressions.asp

我的网摘中也有好的收藏

C#正则表达式详解()
======================================================================
字符^
意义:表示匹配的字符必须在最前边。
例如:/^A/不匹配"an A,"中的'A',但匹配"An A."中最前面的'A'。

字符$
意义:与^类似,匹配最末的字符。
例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。

字符*
意义:匹配*前面的字符0次或n次。
例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不匹配"A goat g
runted"中的任何字符。

字符+
意义:匹配+号前面的字符1次或n次。等价于{1,}。
例如:/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。

字符?
意义:匹配?前面的字符0次或1次。
例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。

字符.
意义:(小数点)匹配除换行符外的所有单个的字符。
例如:/.n/匹配"nay, an apple is on the tree"中的'an'和'on',但不匹配'nay'。


字符(x)
意义:匹配'x'并记录匹配的值。
例如:/(foo)/匹配和记录"foo bar."中的'foo'。匹配子串能被结果数组中的素[1], ..., [n] 返
回,或被RegExp对象的属性$1, ..., $9返回。

字符x|y
意义:匹配'x'或者'y'。
例如:/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。

字符{n}
意义:这里的n是一个正整数。匹配前面的n个字符。
例如:/a{2}/不匹配"candy,"中的'a',但匹配"caandy," 中的所有'a'和"caaandy."中前面的两个
'a'。

字符{n,}
意义:这里的n是一个正整数。匹配至少n个前面的字符。
例如:/a{2,}不匹配"candy"中的'a',但匹配"caandy"中的所有'a'和"caaaaaaandy."中的所有'a'

字符{n,m}
意义:这里的n和m都是正整数。匹配至少n个最多m个前面的字符。
例如:/a{1,3}/不匹配"cndy"中的任何字符,但匹配 "candy,"中的'a',"caandy," 中的前面两个
'a'和"caaaaaaandy"中前面的三个'a',注意:即使"caaaaaaandy" 中有很多个'a',但只匹配前面的三
个'a'即"aaa"。

字符[xyz]
意义:一字符列表,匹配列出中的任一字符。你可以通过连字符-指出一个字符范围。
例如:[abcd]跟[a-c]一样。它们匹配"brisket"中的'b'和"ache"中的'c'。

字符[^xyz]
意义:一字符补集,也就是说,它匹配除了列出的字符外的所有东西。 你可以使用连字符-指出一
字符范围。
例如:[^abc]和[^a-c]等价,它们最早匹配"brisket"中的'r'和"chop."中的'h'。

字符[/b]
意义:匹配一个空格(不要与/b混淆)

字符/b
意义:匹配一个单词的分界线,比如一个空格(不要与[/b]混淆)
例如://bn/w/匹配"noonday"中的'no',//wy/b/匹配"possibly yesterday."中的'ly'。

字符/B
意义:匹配一个单词的非分界线
例如://w/Bn/匹配"noonday"中的'on',/y/B/w/匹配"possibly yesterday."中的'ye'。

字符/cX
意义:这里的X是一个控制字符。匹配一个字符串的控制字符。
例如://cM/匹配一个字符串中的control-M。

字符/d
意义:匹配一个数字,等价于[0-9]。
例如://d/或/[0-9]/匹配"B2 is the suite number."中的'2'。

字符/D
意义:匹配任何的非数字,等价于[^0-9]。
例如://D/或/[^0-9]/匹配"B2 is the suite number."中的'B'。

字符/f
意义:匹配一个表单符

字符/n
意义:匹配一个换行符

字符/r
意义:匹配一个回车符

字符/s
意义:匹配一个单个white空格符,包括空格,tab,form feed,换行符,等价于[ /f/n/r/t/v]。
例如://s/w*/匹配"foo bar."中的' bar'。

字符/S
意义:匹配除white空格符以外的一个单个的字符,等价于[^ /f/n/r/t/v]。
例如://S//w*匹配"foo bar."中的'foo'。

字符/t
意义:匹配一个制表符

字符/v
意义:匹配一个顶头制表符

字符/w
意义:匹配所有的数字和字母以及下划线,等价于[A-Za-z0-9_]。
例如://w/匹配"apple,"中的'a',"$5.28,"中的'5'和"3D."中的'3'。

字符/W 
意义:匹配除数字、字母外及下划线外的其它字符,等价于[^A-Za-z0-9_]。
例如://W/或者/[^$A-Za-z0-9_]/匹配"50%."中的'%'。

字符/n
意义:这里的n是一个正整数。匹配一个正则表达式的最后一个子串的n的值(计数左圆括号)。

例如:/apple(,)/sorange/1/匹配"apple, orange, cherry, peach."中的'apple, orange',下面
有一个更加完整的例子。
注意:如果左圆括号中的数字比/n指定的数字还小,则/n取下一行的八进制escape作为描述。

字符/ooctal和/xhex
意义:这里的/ooctal是一个八进制的escape值,而/xhex是一个十六进制的escape值,允许在一个
正则表达式中嵌入ASCII码。

==========================================================================

检测一个字符串(包括汉字)的长度只能为 20-1000 如果有空格,空格不计算在内。
???一有空格就会错误,

用js比较简单些
<html>
<script language=javascript>
  function cc(obj,len)
  {
  if(obj.value.replace(/[^/x00-/xff]/g,"**").length>len){alert("太长");}
  }
</script>
下面是调用
1.<input type="text" οnblur="cc(this,4)">最长4,汉字2<br/>
1.<input type="text" οnblur="cc(this,4)">最长6,汉字3<br/>
</html>
======================================================================

  (成功)以数字和字母开头结尾,中间包含. - _最长不过18,最短不过4的正则表达式

 ===== ^[A-Za-z0-9][A-Za-z0-9./-_]{2,16}[A-Za-z0-9]$
=======================================================================
  
(成功)输入文本的长度小于10,其中可能包括中文字符
======[/u4e00-/u9fa5]{1,9}|/w{1,9}
=======================================================================
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值