最近研究js客户端检测遇到了各种复杂的正则表达式,在一阵阵晕眩之下买了本大神推荐的正则入门书籍——《正则必知必会》。感觉挺不错的入门书,轻松之下就不知不觉学了蛮多的东西。废话少说,直接来列表:
快速掌握最基本的正则语法
匹配单个字符
.
匹配任意字符\
匹配特殊字符
匹配一组字符
[]
匹配一组字符[a-z]
字符集合区间[A-Z]
字符集合区间[0-9]
字符集合区间[A-z]
字符集合区间^
取非匹配[\b]
Backspace 键
使用元字符
\f
换页符\n
换行符\r
回车符\t
制表符 Tab 键\v
垂直制表符\d
匹配数字(等价于[0-9])\D
匹配非数字\w
匹配字母和数字(等价于[a-zA-Z0-9_])\W
匹配非字母和数字\s
任何一个空白字符(等价于[\f\n\r\t\v])
11. \S
任何一个非空白字符
12. \x
十六进制
13. \0
八进制
14. [:alnum:]
等价于[a-zA-Z0-9]
15. [:alpha:]
等价于[a-zA-Z]
16. [:blank:]
等价于[\t]
17. [:cntrl:]
ASCⅡ 控制字符
18. [:digit:]
等价于[0-9]
19. [:graph:]
等价于[:print:]
20. [:lower:]
等价于[a-z]
21. [:print:]
任何可打印字符
22. [:punct:]
不属于[:alnum:]也不属于[:cntrl:]的任何一个字符
23. [:space:]
任何一个空白字符,包括空格
24. [:upper:]
等价于[A-Z]
25. [:xdigit:]
任何一个十六进制数字,等价于[a-fa-f0-9]
重复匹配
+
匹配一个或多个字符*
匹配零个或多个字符?
匹配零个或一个字符{n}
为重复匹配次数设定一个精确的值{n,m}
为重复匹配次数设定一个区间{n,}
为重复匹配次数设定至少重复n次+?
匹配一个或多个字符,懒惰型元字符*?
匹配零个或多个字符,懒惰型元字符{n,?}
匹配至少重复n次,懒惰型元字符
位置匹配
\b
匹配单词边界45.\B
匹配非单词边界46.\<
匹配单词的开头,部分文本匹配工具不支持\>
匹配单词的结尾,部分文本匹配工具不支持^
匹配字符串开头$
匹配字符串结尾(?m)
分行匹配模式,^
匹配字符串的开头,还将匹配换行符后面的开始位置;以及$
匹配字符串的结尾,还将匹配换行符后面的结束位置。
子表达式
()
子表达式是一个更大的表达式的一部分|
或
回溯引用匹配
\n
引用第n个表达式$n
替换模式,第n个表达式
前后查找
?=
正向前查找?<=
正向后查找?!
负向前查找?<!
负向后查找
条件
(?(backreference)true-regex)
条件语句(如果...则...)(?(backreference)true-regex|false-regex)
条件语句(如果...则...否则...)(?(?=)true-regex)
条件语句(如果匹配不消费了...则...)