正则表达式

定义:用来描述或者匹配一系列符合某个语句规则的字符串
匹配特定数字:
1/d*     / / 匹 配 正 整 数 − [ 1 − 9 ] / d ∗     //匹配正整数 ^-[1-9]/d*   //[19]/d   //匹配负整数
^-?[1-9]/d*     / / 匹 配 整 数 [ 1 − 9 ] / d ∗ ∣ 0    //匹配整数 ^[1-9]/d*|0   //[19]/d0  //匹配非负整数(正整数 + 0)
^-[1-9]/d*|0     / / 匹 配 非 正 整 数 ( 负 整 数 + 0 ) [ 1 − 9 ] / d ∗ / . / d ∗ ∣ 0 / . / d ∗ [ 1 − 9 ] / d ∗    //匹配非正整数(负整数 + 0) ^[1-9]/d*/./d*|0/./d*[1-9]/d*   //+0[19]/d/./d0/./d[19]/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)  //?([19]/d/./d0/./d[19]/d0?/.0+0)  //匹配浮点数
2/d*/./d*|0/./d*[1-9]/d*|0?/.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(([19]/d/./d0/./d[19]/d))0?/.0+0  //匹配非正浮点数(负浮点数 + 0)
注释:处理大量数据时有用,具体应用时注意修正
1.英文句点.符号:匹配单个任意字符。

表达式t.o 可以匹配:tno,t#o,teo等等。不可以匹配:tnno,to,Tno,t正o等。
2、中括号[]:只有方括号里面指定的字符才参与匹配,也只能匹配单个字符。

表达式:t[abcd]n 只可以匹配:tan,tbn,tcn,tdn。不可以匹配:thn,tabn,tn等。
3、| 符号。相当与“或”,可以匹配指定的字符,但是也只能选择其中一项进行匹配。

表达式:t(a|b|c|dd)n 只可以匹配:tan,tbn,tcn,tddn。不可以匹配taan,tn,tabcn等。
4、表示匹配次数的符号

表达式:[0—9]{ 3 } \— [0-9]{ 2 } \— [0-9]{ 3 } 的匹配格式为:999—99—999
因为—符号在正则表达式中有特殊的含义,它表示一个范围,所以在前面加转义字符\。
5、符号:表示否,如果用在方括号内,表示不想匹配的字符。

表达式:[^x] 第一个字符不能是x
6、\S符号:非空字符
7、\s符号:空字符,只可以匹配一个空格、制表符、回车符、换页符,不可以匹配自己输入的多个空格。
8、\r符号:空格符,与\n、\tab相同

-用正则表达式限制只能输入中文:
οnkeyup=“value=value.replace(/[^u4E00-u9FA5]/g,’’)” onbeforepaste=“clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^u4E00-u9FA5]/g,’’))”
-用正则表达式限制只能输入全角字符:
οnkeyup=“value=value.replace(/[^uFF00-uFFFF]/g,’’)” onbeforepaste=“clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^uFF00-uFFFF]/g,’’))”
-用正则表达式限制只能输入数字:
οnkeyup="value=value.replace(/[^d]/g,’’) "onbeforepaste=“clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,’’))”
-用正则表达式限制只能输入数字和英文:
οnkeyup="value=value.replace(/[W]/g,’’) "onbeforepaste=“clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,’’))”

字符:
将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n"匹配字符"n”。"\n"匹配换行符。序列"\“匹配”","(“匹配”("。
字符: ^
匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,^ 还会与"\n"或"\r"之后的位置匹配。
字符:$
匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,$ 还会与"\n"或"\r"之前的位置匹配。
字符:*
零次或多次匹配前面的字符或子表达式。例如,zo* 匹配"z"和"zoo"。* 等效于 {0,}。
字符:+
一次或多次匹配前面的字符或子表达式。例如,"zo+"与"zo"和"zoo"匹配,但与"z"不匹配。+ 等效于 {1,}。
字符:?
零次或一次匹配前面的字符或子表达式。例如,"do(es)?“匹配"do"或"does"中的"do”。? 等效于 {0,1}。
字符:{n}
n 是非负整数。正好匹配 n 次。例如,"o{2}"与"Bob"中的"o"不匹配,但与"food"中的两个"o"匹配。
字符:{n,}
n 是非负整数。至少匹配 n 次。例如,"o{2,}“不匹配"Bob"中的"o”,而匹配"foooood"中的所有 o。"o{1,}“等效于"o+”。"o{0,}“等效于"o*”。
字符:{n,m}
M 和 n 是非负整数,其中 n <= m。匹配至少 n 次,至多 m 次。例如,"o{1,3}"匹配"fooooood"中的头三个 o。‘o{0,1}’ 等效于 ‘o?’。注意:您不能将空格插入逗号和数字之间。


  1. 1-9 ↩︎

  2. 1-9 ↩︎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值