美文网首页程序员正则表达我爱编程
正则表达式(一):常用元字符

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

作者: zhipingChen | 来源:发表于2018-06-20 21:02 被阅读76次

正则是什么

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

经常可以看到正则表达式的句子里包含了一些\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)
. 匹配除换行之外的所有字符 . 单个换行之外所有字符

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

\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

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

\d{3}                      ---------           123
\w{5}\s{5}                 ---------         hello world

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

String line = "hello world!"

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


  1. 分组符号

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

示例:

 ^(\w{4})\s\1\b    ---------     long long ago  ---  >    匹配"long long"  

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

示例:

import re

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

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

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

示例:

import re

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

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

示例:

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"之间的位置

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

^(\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

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

相关文章

  • C# 正则表达式基础

    正则表达式 Regex类 元字符 正则表达式通常用来检查,检索,替换符合某个格式的文本 元字符: 正则表达式语言由...

  • 正则表达式-元字符

    元字符基础正则表达式中具有特殊含义的字符称之为元字符,常用的元字符如下:\ 一般用于转义字符^ 断言目标的开始位置...

  • 正则表达式

    正则表达式元字符 扩展正则表达式元字符

  • 正则表达式

    正则表达式 正则表达式就是记录文本规则的代码 正则表达式常用的元字符 正则表达式常用的限定符 正则表达式举例:这里...

  • 正则表达式笔记

    正则表达式 元字符 下面列举一些正则表达式里的元字符及其作用 元字符 |说明 . ...

  • 正则表达式汇总

    1.正则表达式一般命名为regex 2.JS正则表达式常用的方法 方法举例 3.常用限定符号 4.常用元字符 5....

  • Python基础022--正则表达式

    正则表达式模块、贪婪匹配和非贪婪匹配、正则分组、match和search的使用 常用的正则表达式元字符 正则表达式...

  • 正则表达式

    正则表达式经常用到,这篇文件做一下总结记录 一、字符 字符:元字符和字面量字符元字符是表示特殊含义的字符,包括:^...

  • iOS中正则表达式使用及关键语法

    iOS中高效使用正则表达式 代码示例展示 常用的表达式 正则表达式的关键语法 表1.常用的元字符 字符转义如果你想...

  • 正则表达式

    正则表达式中具有特殊含义的字符称之为元字符,常用的元字符有: \ 一般用于转义字符 \d 匹配数字 \s匹配任意的...

网友评论

本文标题:正则表达式(一):常用元字符

本文链接:https://www.haomeiwen.com/subject/lzyreftx.html