文档章节

正则表达式

o
 osc_mervd488
发布于 2018/04/24 15:53
字数 1907
阅读 23
收藏 0

精选30+云产品,助力企业轻松上云!>>>

1 \   指出接着的字符为特殊字符。
例如:/b/匹配字符“b”,通过在b前面加一个反斜杠\,也就是/\b/,则该字符变成特殊字符,表示匹配一个单词的分界线
 
2 ^ 表示匹配的字符必须在最前边。
例如:/^A/ 不匹配“an A”中的“A”,但匹配“An A”中最前面的“A”
 
3 $
与^类似,匹配最末的字符。
例如:/t$/不匹配“eater”中的“t”,但匹配“eat”中的“t”
 
4 *
匹配*前面的字符0次或n次。
例如:/bo*/匹配“A ghost booooed”中的“boooo”或“A bird warbled”中的“b”,但不匹配“A goat grunted”中的任何字符
 
5 +
匹配+号前面的字符1次或n次。等价于{1,}。
例如:/a+/匹配“candy”中的“a”和“caaaaaaandy”中的所有“a”
 
6 ?
匹配?前面的字符0次或1次。
例如:/e?le?/匹配“angel”中的“el”和“angle”中的“le”
 
7 .
(小数点)匹配除换行符外的所有单个的字符。
例如:/.n/匹配“nay, an apple is on the tree”中的“an”和“on”,但不匹配“nay”
 
8 (x)
匹配'x'并记录匹配的值。
例如:/(foo)/匹配和记录“foo bar”中的“foo”。匹配子串能被结果数组中的元素[1], ..., [n]返回,或被RegExp对象的属性$1, ..., $9返回
 
9 x|y
匹配“x”或者“y”。例如:/green|red/匹配“green apple”中的“green”和“red apple”中的“'red”
 
10 {n}
这里的n是一个正整数。匹配前面的n个字符。例如:/a{2}/不匹配“candy”中的“a”,但匹配“caandy”中的所有“a” 和“caaandy”中前面的两个“a”
 
11 {n,}
这里的n是一个正整数。匹配至少n个前面的字符。例如:/a{2,}不匹配“candy”中的“a”,但匹配“caandy”中的所有“a”和“caaaaaaandy”中的所有“a”
 
12 {n,m}
这里的n和m都是正整数。匹配至少n个最多m个前面的字符。
例如:/a{1,3}/不匹配“cndy”中的任何字符,但匹配“candy”中的“a”,“caandy”中的前面两个“a”和“caaaaaaandy”中前面的3个“a”,注意:即使“caaaaaaandy”中有很多个“a”,但只匹配前面的3个“a”即“aaa”
 
13 [xyz]
字符列表,匹配列出中的任意字符。可以通过连字符-指出一个字符范围。
例如:[abcd]跟[a-c]一样。它们匹配“brisket”中的“b”和“che”中的“c”
 
14 [^xyz]
字符补集,匹配除了列出的字符外的所有东西。可以使用连字符-指出一个字符范围。
例如:[^abc]和[^a-c]等价,它们最早匹配“brisket”中的“r”和“chop”中的“h”
 
15 [\b]
匹配一个空格(不要与\b混淆)
 
16 \b
匹配一个单词的分界线,比如一个空格(不要与[\b]混淆)。
例如:/\bn\w/匹配“noonday”中的“no”,/\wy\b/匹配“possibly yesterday”中的“ly”
 
17 \B
匹配一个单词的非分界线。
例如:/\w\Bn/匹配“noonday”中的“on”,/y\B\w/匹配“possibly yesterday”中的“ye”
 
18 \cX
X是一个控制字符。匹配一个字符串的控制字符。
例如:/\cM/匹配一个字符串中的control-M
 
19 \d
匹配一个数字,等价于[0-9]。
例如:/\d/或/[0-9]/匹配“B2 is the suite number”中的“2”
 
20 \D
匹配任何非数字,等价于[^0-9]。
例如:/\D/或/[^0-9]/匹配“B2 is the suite number”中的“B”
 
21 \f
匹配一个表单符
 
22 \n
匹配一个换行符
 
23 \r
匹配一个回车符
 
24 \s
匹配一个white空格符,包括空格,tab,form feed,换行符,等价于[ \f\n\r\t\v]。
例如:/\s\w*/匹配“foo bar”中的“ bar”
 
25 \S
匹配一个制表符
 
26 \v
匹配一个顶头制表符
 
27 \t
匹配一个制表符
 
28 \w
匹配所有的数字和字母以及下划线,等价于[A-Za-z0-9_]。
例如:/\w/匹配“apple”中的'a',“$5.28”中的“5”和“3D”中的“3”
 
29 \W
匹配除数字、字母外及下划线外的其他字符,等价于[^A-Za-z0-9_]。
例如:/\W/或者/[^$A-Za-z0-9_]/匹配“50%”中的“%”
 
30 \n
这里的n是一个正整数。匹配一个正则表达式最后一个子串的n的值(计数左圆括号)。
例如:/apple(,)\sorange\1/匹配“apple, orange, cherry, peach”中的“apple, orange”。注意:如果左圆括号中的数字比\n指定的数字还小,则\n取下一行的八进制escape作为描述
 
31 \ooctal 和 \xhex
这里的\ooctal是一个八进制的escape值,而\xhex是一个十六进制的escape值,允许在一个正则表达式中嵌入ASCII码
 
 
1.正则表达式 直接量字符
  字符           匹配

\o              //NULL字符(\u0000)
\t              //制表符(\u0009)
\n              //换行符(\u000A)

\v              //垂直制表符(\u000B)
\f              //换页符(\u000C)
\r              //回车符(\u000D)

\xnn            //由十六进制数nn指定的拉丁字符,例如,\x0A等价于\n
\uxxxx          //由十六进制数nnnn指定的Unicode字符,例如\u0009等价于\t
\cX             //控制字符^X,例如\cJ等价于换行符\n


2.正则表达式 字符类
  字符           匹配

[...]           //方括号内的任意字符
[^...]          //非方括号内的任意字符

.               //除了换行符和其他的Unicode行终止符之外的任意字符

\w              //任何ASCII字符组成的单词,等价于[a-zA-Z0-9]
\W              //任何非ASCII字符组成的单词,等价于[^a-zA-Z0-9]

\s              //任何Unicode空白字符
\S              //任何非Unicode空白字符,注意\W和\S的区别

\d              //任何ASCII数字,等价于[0-9]
\D              //任何非ASCII数字,等价于[^0-9]

[\b]            //退格直接量(特例)


3.正则表达式 重复字符语法
  字符         含义

{n,m}          //匹配前一项至少n次,最多m次
{n,}           //匹配前一项至少n次
{n}            //匹配前一项n次

?             //匹配前一项0次或者1次,也就是说前一项是可选的,等价于{0,1}
+              //匹配前一项至少一次,等价于{1,}
*              //匹配前一项至少0次,等价于{0,}

4.正则表达式 选择、分组和引用字符
  字符         含义

|             //选择,匹配的是该符号左边或者右边的表达式
(...)         //组合,将几项组合合并成一个单元,这个单元可通过"*","+","?"和"|"
                等符号组合加以修饰,而且可以记住这个组合相匹配的字符串,用以后面的匹配
(?:...)       //只组合,将几项组合合并成一个单元,但是不记忆,不能用以后面的匹配
\n            //和第n个分组第一次匹配的字符相匹配,组是括号里面的表达式

5.正则表达式 锚字符
  字符         含义

^             //匹配字符串的开头,在多行检索中,匹配一行的开始
$             //匹配字符串的结尾,在多行检索中,匹配一行的结尾
\b            //匹配单词的边界,简而言之,就是位于字符\w和\W之间,或者位于\W和
              //字符串开始或者结尾的位置,但是需要注意,[\b]是退格符

\B            //匹配非单词边界位置
(?=p)         //零宽正向先行断言,要求接下来的字符都与p匹配,但是不能包括匹配p的那些字符
(?!p)         //零宽负向先行断言,要求接下来的字符不与p匹配

6.正则表达式  修饰符
  字符         含义

i             //执行不区分大小写的匹配
g             //执行一个全局匹配,简而言之,找到所有的匹配,而不是找到第一个就停止
m             //多行匹配模式,^匹配一行的开始和字符串的开始,$匹配行的结尾和字符串的结尾


 

 

o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

2020-07-03:有1亿个数字,其中有2个是重复的,快速找到它,时间和空间要最优

福哥答案2020-07-03: 1.双重遍历。 时间复杂度是O(N^2)。 2.排序。 采用外部排序。时间复杂度是O(NlogN)。 3.遍历加哈希存储。 空间换时间,时间复杂度是O(N),空间复杂度是O(N)。这种方法适...

osc_ix000whh
13分钟前
0
0
O2OA开源免费开发平台:在O2门户页面中使用React(三)

在前面的章节中,我们介绍了两种在O2OA中使用React开发应用的方式,已经可以满足绝大多数的情况了。如果您考虑完全脱离O2的web服务器,自己搭建web服务器,那就请阅读本章。   我们还是使用...

O2OA企业信息化平台
14分钟前
18
0
harbor 2.0 搭建docker私有仓库

harbor Harbor 是一个CNCF基金会托管的开源的可信的云原生docker registry项目,可以用于存储、签名、扫描镜像内容,Harbor 通过添加一些常用的功能如安全性、身份权限管理等来扩展 docker r...

osc_l7zl78wt
15分钟前
5
0
Java并发编程(06):Lock机制下API用法详解

本文源码:GitHub·点这里 || GitEE·点这里 一、Lock体系结构 1、基础接口简介 Lock加锁相关结构中涉及两个使用广泛的基础API:ReentrantLock类和Condition接口,基本关系如下: Lock接口 ...

osc_kiub62pt
16分钟前
22
0
DNS存在的问题

1、域名缓存问题 本地做一个缓存,直接返回缓存数据。可能会导致全局负载均衡失败,因为上次进行的缓存,不一定是这次离客户最近的地方,可能会绕远路。 2、域名转发问题 如果是A运营商将解析...

mind-blowing
17分钟前
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部