简单表达式
单字符模式
/a/ /7/ /M/
/a7M/<!-- 匹配:a或7或M -->
没有串联运算符。
字符匹配
点号 .
匹配字符串中的各种打印或非打印字符,除了换行符 \n 和 \r。
/a.c/
匹配: aac、abc、acc、adc 等等,以及 a1c、a2c、a-c 和 a#c
若要匹配包含文件名和点号的字符串,用 \.
。
/filename\.ext/
匹配 filename.ext
注意,上述语法适用于单个字符。
用户名正则表达式?(根据具体需求具体确定)
1、26 个大小写英文字母表示为 a-zA-Z。
2、数字表示为 0-9。
3、下划线 _和中划线 -。
用+ 表示 1 次或多次出现。
var str = "abc123-_def";
var patt1 = /[a-zA-Z0-9_-]+/;
document.write(str.match(patt1));
<!--匹配:abc123-_def -->
var str1 = "abc123def";
var str2 = "abc123_def";
var patt = /[a-zA-Z0-9_]+/;
document.write(str1.match(patt));
<!--匹配 abc123def -->
document.write(str2.match(patt));
<!--匹配 abc123_def -->
匹配 HTML 标签及内容
标签,以iframe 为例:
/<iframe(([\s\S])*?)<\/iframe>/
匹配 id=“mydiv” 的 div 标签:
/<div id="mydiv"(([\s\S])*?)<\/div>/
匹配所有 img 标签:
/<img.*?src="(.*?)".*?\/?>/gi
中括号表达式
"中括号表达式"列表:字符括在中括号内。
在中括号内,普通字符依然表示其本身。大多数特殊字符则失去意义。
例外:
如果 ] 字符不是第一项,它结束一个列表。若要匹配列表中的 ] 字符,请将它放在第一位,紧跟在开始 [ 后面。
\ 字符继续作为转义符。使用 \\
匹配 \ 字符。
中括号表达式中的字符只匹配该位置的单个字符。
/Chapter [12345]/
注意匹配结果中的空格位置与表达式中相同。
用范围?
连字符 -
。前面是开始值,后面是结束值。两者都在范围内。
/Chapter [1-5]/
<!-- 与上式一样,匹配 Chapter 1、Chapter 2、Chapter 3、Chapter 4 和 Chapter 5 -->
注意:按 Unicode 排序顺序,开始值必须在结束值的前面。
若要在中括号表达式中包括连字符?
1) 用反斜杠将它转义:
[\-]
2)将连字符放在中括号列表的开始或结尾。下面的表达式匹配所有小写字母和连字符:
[-a-z]或[a-z-]
3)一个范围,开始字符值<连字符,结束字符值>=连字符。
[!--]
[!-~]
查找不在列表或范围内的所有字符?
将插入符号 ^ 放在列表的开头。不在开头,则它匹配其本身。
/Chapter [^12345]/ <!--匹配1、2、3、4 或 5 之外的任何数字和字符-->
<!--如Chapter 7>
<!--可以使用连字符 - -->
/Chapter [^1-5]/
指定任何大写或小写字母或任何数字
/[A-Za-z0-9]/
替换和分组
|
字符,在两个或多个选项之间选择。
/^Chapter|Section [1-9][0-9]{0,1}$/
<!-- 如果输入字符串是 Chapter 22,那么上面的表达式只匹配单词 Chapter。如果输入字符串是 Section 22,那么该表达式匹配 Section 22。 -->
可以使用括号来限制替换的范围。
括号也用于创建子表达式,并可能捕获它们以供以后使用,(内容:反向引用)。
/^(Chapter|Section) [1-9][0-9]{0,1}$/ <!--用括号来组合 Chapter 和 Section-->
Chapter|Section 周围的括号还将捕获两个匹配字中的任一个供以后使用。上面的表达式中只有一组括号,因此,只有一个被捕获的"子匹配项"。
在括号内正则表达式模式之前放置 ?:
,防止匹配被保存以备将来使用。
/^(?:Chapter|Section) [1-9][0-9]{0,1}$/ <!--提供相同的能力而不保存子匹配项-->
“预测先行”
正向预测先行使用 ?=
,匹配处于括号中匹配正则表达式模式的起始点的搜索字符串。
反向预测先行使用 ?!
,匹配处于与正则表达式模式不匹配的字符串的起始点的搜索字符串。
/Windows(?=95 |98 |NT )/
<!--匹配 Windows 95、Windows 98 和 Windows NT。如果第一个匹配Windows 95,则保留Windows并继续进行匹配-->
其他示例
正则表达式 描述
/\b([a-z]+) \1\b/gi 一个单词连续出现的位置。
/(\w+):\/\/([^/:]+)(:\d*)?([^# ]*)/ 匹配一个 URL 解析为协议、域、端口及相对路径。
/^(?:Chapter|Section) [1-9][0-9]{0,1}$/ 定位章节的位置。
/[-a-z]/ a至z共26个字母再加一个 - 号。
/ter\b/ 以ter结尾的单词,如chapter。
/\Bapt/ apt在中间的单词(非单词边界),可匹配 chapter,而不能匹配 aptitude。
/^\s*$/ 匹配空行。
/\d{2}-\d{5}/ 验证由两位数字、一个连字符再加 5 位数字组成的 ID 号。
<[a-zA-Z]+.*?>([\s\S]*?)</[a-zA-Z]*?> 匹配 HTML 标记。
正则表达式 描述
hello 匹配 {hello}
gray|grey gr(a|e)y gr[ae]y 匹配 {gray, grey}
b[aeiou]bble 匹配 {babble, bebble, bibble, bobble, bubble}
[b-chm-pP]at|ot 匹配 {bat, cat, hat, mat, nat, oat, pat, Pat, ot}
colou?r 匹配 {color, colour}
rege(x(es)?|xps?) 匹配 {regex, regexes, regexp, regexps}
go*gle 匹配 {ggle, gogle, google, gooogle, goooogle, ...}
go+gle 匹配 {gogle, google, gooogle, goooogle, ...}
g(oog)+le 匹配 {google, googoogle, googoogoogle, googoogoogoogle, ...}
z{3} 匹配 {zzz}
z{3,6} 匹配 {zzz, zzzz, zzzzz, zzzzzz}
z{3,} 匹配 {zzz, zzzz, zzzzz, ...}
[Bb]rainf\*\*k 匹配 {Brainf**k, brainf**k}
\d 匹配 {0,1,2,3,4,5,6,7,8,9}
1\d{10} 匹配 11 个数字,以 1 开头
[2-9]|[12]\d|3[0-6] 匹配 2 到 36 范围内的整数
Hello\nworld 匹配 Hello 后跟换行符,后跟 world
\d+(\.\d\d)? 包含一个正整数或包含两位小数位的浮点数。
[^*@#] 排除 *、@ 、# 三个特色符号
//[^\r\n]*[\r\n] 匹配 // 开头的注释
^dog 匹配以 "dog" 开始
dog$ 匹配以 "dog" 结尾
^dog$ 只"dog"
一、校验数字的表达式
数字:^[0-9]*$
n位:^\d{n}$
至少n位:^\d{n,}$
m-n位:^\d{m,n}$
0和非0开头:^(0|[1-9][0-9]*)$
非零开头的最多带两位小数:^([1-9][0-9]*)+(\.[0-9]{1,2})?$
带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})$
正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$
有两位小数的正实数:^[0-9]+(\.[0-9]{2})?$
有1~3位小数的正实数:^[0-9]+(\.[0-9]{1,3})?$
非零的正整数:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$
非零的负整数:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$
非负整数:^\d+$ 或 ^[1-9]\d*|0$
非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
非负浮点数:^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
非正浮点数:^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
正浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
负浮点数:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
浮点数:^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$
二、校验字符的表达式
汉字:^[\u4e00-\u9fa5]{0,}$
英文和数字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
长度为3-20的所有字符:^.{3,20}$
由26个英文字母组成的字符串:^[A-Za-z]+$
26个大写:^[A-Z]+$
26个小写:^[a-z]+$
由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
中文、英文、数字包括下划线:^[\u4E00-\u9FA5A-Za-z0-9_]+$
中文、英文、数字但不包括下划线等符号:^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
可以输入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]+
禁止输入含有~的字符:[^~]+
三、特殊需求表达式
Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?
InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$
手机号码:^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$
电话号码("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
电话号码正则表达式(支持手机号码,3-4位区号,7-8位直播号码,1-4位分机号): ((\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}))$)
身份证号(15位、18位数字),最后一位校验位,可能为数字或字符X:(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)
帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$
强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{8,10}$
强密码(必须包含大小写字母和数字的组合,可以使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
日期格式:^\d{4}-\d{1,2}-\d{1,2}
一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
钱的输入格式:
4种常用形式:"10000.00" 和 "10,000.00", 和没有 "分" 的 "10000" 和 "10,000"
以0开头或不以0开头,非负,可能有逗号,可能有小数。如果有小数点,小数点后面一定有数字。
1到3个数字,后面跟着任意个逗号+3个数字,(逗号为可选):^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
"+"可以用"*"替代(但结果会包含了空字符串)
中文字符:[\u4e00-\u9fa5]
双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
空白行的正则表达式:\n\s*\r (可以用来删除空白行)
HTML标记的正则表达式:<(\S*?)[^>]*>.*?|<.*? /> ( 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等))
腾讯QQ号:[1-9][0-9]{4,} (从10000开始)
中国邮政编码:[1-9]\d{5}(?!\d) (6位数字)
IPv4地址:((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})(\.((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})){3}
工具
在线测试 https://c.runoob.com/front-end/854/
可视化 https://c.runoob.com/front-end/7625/#!flags=&re=%5E(a%7Cb)*%3F%24
RegExr – 正则表达式在线测试工具 https://regexr.com/
Regulex – 正则表达式在线测试工具 https://regex101.com/