正则表达式基础语法以及示例

正则表达式

一:什么是正则表达式

是记录文本规则的代码

二:常用的元字符

代码说明
\d[0-9] 匹配任意数字
\D匹配任何非数字
\b匹配单词的开始或结束
\w[a-z0-9A-Z_] 匹配除换行符以外的任意字符
\s匹配任意的空白符
^匹配字符串的开始
$匹配字符串的结束
^\d{5,12}$5到12位数字

三:转义字符 \

查找 ( . ) ( * ) ( \ ) 等元字符的时候,但是我们不是用元字符的含义,就是单纯的符号,但会被解释成别的意思,这时候就需要使用“\”来取消它的特殊意义,因此应该用 ( \ . ) ( * ) ( \ )
例如:unibetter.com匹配unibetter.com,C:\Windows匹配C:\Windows。

四:重复匹配

限定符,指定数量的代码

代码(语法)说明
*重复零次或更多次
+重复一次或更多次
?重复零次或一次
{n}重复n次
{n,}重复n次或更多次
{n,m}重复n到m次
^\d{5,12}$5到12位数字

五:字符类

匹配没有预定义元字符的字符集合(比如元音字母a,e,i,o,u), 只需要在方括号里列出它们就行了

[aeiou]就匹配任何一个英文元音字母 ,[.?!]匹配标点符号(.或?或!)。

(?0\d{2}[) -]?\d{8}:首先是一个转义字符(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。

?:表示出现1次或0次

六:分枝条件

用|把不同的规则分隔开,相当于或的关系

\d{5}-\d{4}|\d{5} :这个表达式用于匹配美国的邮政编码。美国邮编的规则是5位数字,或者用连字号间隔的9位数字。之所以要给出这个例子是因为它能说明一个问题:使用分枝条件时,要注意各个条件的顺序。如果你把它改成\d{5}|\d{5}-\d{4}的话,那么就只会匹配5位的邮编(以及9位邮编的前5位)。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。

七:分组

(\d{1,3}.){3}匹配三位数字加上一个英文句号(这个整体也就是这个分组)重复3次

八:反义

查找不属于某个能简单定义的字符类的字符

代码/语法说明
\W匹配任意不是字母,数字,下划线,汉字的字符
\S匹配任意不是空白符的字符
\D匹配任意非数字的字符
\B匹配不是单词开头或结束的位置
[^x]匹配除了x以外的任意字符
[^aeiou]匹配除了aeiou这几个字母以外的任意字符

九:后项引用

后向引用用于重复搜索前面某个分组匹配的文本。
\1:代表分组1匹配的文本。
\b(\w+)\b\s+\1\b可以用来匹配重复的单词,像go go, 或者kitty kitty

十:零宽断言

零宽度正预测先行断言(?=exp)
断言自身出现的位置的后面能匹配表达式exp。比如\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分(除了ing以外的部分),如查找I’m singing while you’re dancing.时,它会匹配sing和danc。
零宽度正回顾后发断言(?<=exp)
断言自身出现的位置的前面能匹配表达式exp。比如(?<=\bre)\w+\b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找reading a book时,它匹配ading。

十一:负向零宽断言详解

零宽度负预测先行断言(?!exp):
断言此位置的后面不能匹配表达式exp。例如:\d{3}(?!\d)匹配三位数字,而且这三位数字的后面不能是数字;\b((?!abc)\w)+\b匹配不包含连续字符串abc的单词
零宽度正回顾后发断言(?

十二:注释

小括号的另一种用途是通过语法(?#comment)来包含注释,就看不见啦
例如:

2[0-4]\d(?#200-249)|25[0-5](?#250-255)|[01]?\d\d?(?#0-199)。

十三:贪婪和懒惰

贪婪:匹配尽可能多的字符(a.*b)
a.*b:它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。
懒惰:匹配尽可能少的字符(a.*?b)
a.*?b:匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。

十四:所有元字符

字符描述
\将下一个字符标记为一个特殊字符、或一个原义字符、或一个 后向引用、或一个八进制转义符。例如,’n’ 匹配字符 “n”。’\n’ 匹配一个换行符。序列 ‘\’ 匹配 “\” 而 “(” 则匹配 “(“。
^匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置。
$匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置。
*匹配前面的子表达式零次或多次。例如,zo* 能匹配 “z” 以及 “zoo”。 * 等价于{0,}。
+匹配前面的子表达式一次或多次。例如,’zo+’ 能匹配 “zo” 以及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}。
?匹配前面的子表达式零次或一次。例如,”do(es)?” 可以匹配 “do” 或 “does” 中的”do” 。? 等价于 {0,1}。
{n}n 是一个非负整数。匹配确定的 n 次。例如,’o{2}’ 不能匹配 “Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o。
{n,}n 是一个非负整数。至少匹配n 次。例如,’o{2,}’ 不能匹配 “Bob” 中的 ‘o’,但能匹配 “foooood” 中的所有 o。’o{1,}’ 等价于 ‘o+’。’o{0,}’ 则等价于 ‘o*’。
{n,m}m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。刘, “o{1,3}” 将匹配 “fooooood” 中的前三个 o。’o{0,1}’ 等价于 ‘o?’。请注意在逗号和两个数之间不能有空格。
?当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 “oooo”,’o+?’ 将匹配单个 “o”,而 ‘o+’ 将匹配所有 ‘o’。
.匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用象 ‘[.\n]’ 的模式。
x|y匹配 x 或 y。例如,’z
[xyz]字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以匹配 “plain” 中的 ‘a’。
[^xyz]负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以匹配 “plain” 中的’p’。
[a-z]字符范围。匹配指定范围内的任意字符。例如,’[a-z]’ 可以匹配 ‘a’ 到 ‘z’ 范围内的任意小写字母字符。
[^a-z]负值字符范围。匹配任何不在指定范围内的任意字符。例如,’[^a-z]’ 可以匹配任何不在 ‘a’ 到 ‘z’ 范围内的任意字符。
\b匹配一个单词边界,也就是指单词和空格间的位置。例如, ‘er\b’ 可以匹配”never” 中的 ‘er’,但不能匹配 “verb” 中的 ‘er’。
\B匹配非单词边界。’er\B’ 能匹配 “verb” 中的 ‘er’,但不能匹配 “never” 中的 ‘er’。
\cx匹配由x指明的控制字符。例如, \cM 匹配一个 Control-M 或回车符。 x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一个原义的 ‘c’ 字符。
\d匹配一个数字字符。等价于 [0-9]。
\D匹配一个非数字字符。等价于 [^0-9]。
\f匹配一个换页符。等价于 \x0c 和 \cL。
\n匹配一个换行符。等价于 \x0a 和 \cJ。
\r匹配一个回车符。等价于 \x0d 和 \cM。
\s匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。
\S匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
\t匹配一个制表符。等价于 \x09 和 \cI。
\v匹配一个垂直制表符。等价于 \x0b 和 \cK。
\w匹配包括下划线的任何单词字符。等价于’[A-Za-z0-9_]’。
\W匹配任何非单词字符。等价于 ‘[^A-Za-z0-9_]’。
\xn匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。例如, ‘\x41’ 匹配 “A”。’\x041’ 则等价于 ‘\x04’ & “1”。正则表达式中可以使用 ASCII 编码。.
\num匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。例如,’(.)\1’ 匹配两个连续的相同字符。
\n标识一个八进制转义值或一个后向引用。如果 \n 之前至少 n 个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。
\nm标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。
\nml如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八进制转义值 nml。
\un匹配 n,其中 n 是一个用四个十六进制数字表示的 Unicode 字符。例如, \u00A9 匹配版权符号 (?)。

十五:应用举例

1:匹配身份证号
正则表达式:

(^\d{15}$)|(^\d{17}([0-9]|X)$)

匹配形式如:15位或者18位身份证

2:匹配电子邮箱
正则表达式:

/^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a-z]{2})?$/i

3:匹配手机号
正则表达式:\d{3}-\d{8}|\d{4}-\d{7}
匹配形式如:( 0511-4405222)
正则表达式:(^([0]\d{2}|\d{4}))(\d{6,7}$)
匹配形式如:((021)1234567)

4:中国电话号码
正则表达式 :((d{3,4})|d{3,4}-)?d{7,8}(-d{3})*
匹配形式如:0511-4405222 或者021-87888822 或者 021-44055520-555 或者 (0511)4405222

5:中国邮政编码
正则表达式 :d{6}
匹配形式如:215421

6:电子邮件(简单不精确)
正则表达式 :w+([-+.]w+)@w+([-.]w+).w+([-.]w+)*
匹配形式如:justali@justdn.com

以上是我对正则表达式的基础的理解,有些概念觉得也没有必要深刻的理解,开始阶段觉得学会使用基础语法,了解基础用法,会应用就够用了。
这篇文章算是自己的学习笔记,参考就好,自己都觉得很low
  • 12
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于 Python 正则表达式的零基础,我可以给你一些简单的介绍和示例。 首先,正则表达式是一种用来匹配和操作字符串的强大工具。它可以帮助我们在文本中搜索、替换、分割等操作,使用的时候需要导入 re 模块。 下面是一个简单的示例代码,它展示了如何使用正则表达式在字符串中查找特定的模式: ```python import re # 定义一个字符串 string = "Hello, world! 2021 is here." # 定义一个简单的正则表达式模式,查找所有的小写字母 pattern = r"[a-z]" # 使用 findall() 方法查找所有匹配的结果 result = re.findall(pattern, string) # 打印结果 print(result) # ['e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd', 'i', 's', 'h', 'e', 'r', 'e'] ``` 在上面的代码中,我们使用了 `re.findall()` 方法来查找字符串中所有匹配模式的结果。在这个例子中,我们定义了一个简单的正则表达式模式 `[a-z]`,它会匹配所有的小写字母。然后可以通过打印 `result` 来查看找到的结果。 除了 `findall()` 方法,正则表达式还有其他常用的方法,比如 `search()`、`match()`、`sub()` 等。你可以根据具体的需求选择合适的方法来使用。 当然,正则表达式的语法非常丰富和复杂,上面只是一个简单的示例。如果你想深入学习正则表达式,可以参考 Python 官方文档中有关 re 模块的详细说明,或者查看一些专门的正则表达式教程和资料。希望对你有所帮助!如果有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值