前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >正则表达式(一):常用元字符

正则表达式(一):常用元字符

作者头像
zhipingChen
发布2018-09-13 15:36:35
2.5K0
发布2018-09-13 15:36:35
举报
文章被收录于专栏:编程理解编程理解

正则是什么

正则表达式是一种字符串模式,用来对某些规则的文本内容进行处理。利用字符串构成成的数据结构,来完成对文本内容的匹配。

经常可以看到正则表达式的句子里包含了一些\d\w()之类的符号,这些特殊格式的符号可以看做正则结构中的元素,这些符号也成之为元字符,下面介绍下这些元字符的作用。

常用元字符

下面列出正则中常用元字符及表示意思,这些通用元字符的使用在不同语言中表达作用是相同的。

  1. 匹配字符内容

符号

代表意思

使用场景

\d

数字0-9

\d 匹配单个数字,1、2、3

\D

非数字

\D 匹配单个非数字,a、-、'

\w

字母、数字、下划线

\w 匹配单个字母、数字、下划线,a、1、_

\W

非字母、数字、下划线

\W 匹配单个非字母、数字、下划线,{、-、[

\s

空白字符

\s 匹配单个空格、回车(\n)、制表符(\t)

\S

非空白字符

\S 匹配单个非空格、换行(\n)、制表符(\t)

.

匹配除换行之外的所有字符

. 单个换行之外所有字符

以上表格中元字符为常用通配字符,使用形式如:

代码语言:javascript
复制
\d\d\d                       ---------           123
\w\w\w\w\w\s\w\w\w\w\w       ---------         hello world

但是上述写法存在一个很明显的缺陷,就是\d、\w的重复次数问题。所以下面列举表达次数的元字符

  1. 匹配次数

符号

代表意思

使用场景

*

0次及0次以上

\d* 匹配数字,123、02、空

+

1次及1次以上

\d+ 匹配数字,123、02、3

?

0次或1次

\d? 匹配数字,2、空

{m,n}

m次到n次

\d{1,3} 匹配数字,2、12、123

{n}

n次

\d{2} 匹配数字,12

{n,}

n次及n次以上

\d{2,} 匹配数字,12、123、1234

有了表达次数的元字符后,上述形式的字符串模板写法就简单些了

代码语言:javascript
复制
\d{3}                      ---------           123
\w{5}\s{5}                 ---------         hello world

但是只有通配符号、和次数的元字符还不足以应对常用场景:

代码语言:javascript
复制
String line = "hello world!"

这里如果要匹配整个字符串内容,或者只匹配hello这一个单词,也就是需要对字符串的位置进行校验,下面列出匹配位置的元字符


  1. 分组符号

在继续之前,首先介绍下"()",这里的小括号"()",称之为分组,分组匹配的内容可以在后续的正则中重复使用,只需要指定分组的序号即可。分组的序号是从左往右以此递增的

示例:

代码语言:javascript
复制
 ^(\w{4})\s\1\b    ---------     long long ago  ---  >    匹配"long long"  

分组的作用,除了提供后续引用之外,也用作捕获组,即正则中分组对应的匹配内容

示例:

代码语言:javascript
复制
import re

reg = "(\w{2})(\w{3})"
print(re.match(reg,"hello").groups())
输出结果:
('he', 'llo')
he
llo

由例子中可以看出这里的()分组捕获的匹配内容

有捕获分组,自然也有非捕获分组,在分组开头添加?:,表示该分组对应内容为非捕获分组

示例:

代码语言:javascript
复制
import re

reg = "(?:\w{2})(\w{3})"
print(re.match(reg,"hello").groups())
print(re.match(reg,"hello").group(1))
输出结果:
('llo',)
llo

其中分组的序号由"("出现的顺序确定,第一个"("序号为1,从左往右递增

示例:

代码语言:javascript
复制
import re

reg = "((?:\w{2})(\w{3}))"
print(re.match(reg,"hello").groups())
print(re.match(reg,"hello").group(1))
print(re.match(reg,"hello").group(2))
输出结果:
('hello', 'llo')
hello
llo

  1. 匹配位置

符号

代表意思

使用场景

^

字符串开始位置

(^)abc 匹配字符串开头位置,a前面的位置

$

字符串结束位置

abc($) 匹配字符串结束位置,c后面的位置

\b

单词(\w)与非单词之间的位置

a(\b)= 匹配"a"与"="之间的位置

\B

字符与字符之间的位置

a(\B)b 匹配"a"与"b"之间的位置

这里的元字符只是匹配位置,通过使用位置元字符来限制、过滤指定位置条件的内容。

代码语言:javascript
复制
^(\w{5})\b   -----      hello world ->  匹配内容为: hello

这里的匹配过程是:

  • ^指定字符串开头位置
  • \w{5}匹配内容
  • \b用来匹配"o"于空格之间的位置
  1. 其他元字符

符号

代表意思

使用场景

[]

匹配范围

[a-zA-Z] 匹配单个英文字母

^

在上面的匹配位置元字符中,仅仅介绍了匹配字符串开头位置的作用,这里另外一个作用就是放在范围元字符中,起到取反的作用

[^a-d] 匹配单个非a,b,c,d四个英文字母之外的字符

\

转义元字符

1\+ 匹配"1+"

|

分支条件

ab|cd 匹配ab、cd

关于断言、懒惰匹配相关内容在下一章介绍正则表达式(二):断言

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.06.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 正则是什么
  • 常用元字符
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档