美文网首页
正则表达式笔记

正则表达式笔记

作者: 英文原版童书 | 来源:发表于2020-11-13 15:21 被阅读0次

    1.

    括号在正则表达式中有特殊的含义,但是如果你需要在文本中匹配括号,怎么办?例如,你要匹配的电话号码,可能将区号放在一对括号中。在这种情况下,就需要用倒斜杠 \    对(  和    )进行字符转义。

    2.

    字符 | 称为“管道”。希望匹配许多表达式中的一个时,就可以使用它。例如,正则表达式r'Batman|Tina Fey'将匹配'Batman'或'Tina Fey'。

    3.

    也可以使用管道来匹配多个模式中的一个,作为正则表达式的一部分。例如,假设你希望匹配'Batman'、'Batmobile'、'Batcopter'和'Batbat'中任意一个。因为所有这些字符串都以Bat开始,所以如果能够只指定一次前缀,就很方便。这可以通过括号实现。

    >>> batRegex = re.compile(r'Bat(man|mobile|copter|bat)')

    >>> mo = batRegex.search('Batmobile lost a wheel')

    >>> mo.group()

    'Batmobile'

    >>> mo.group(1)

    'mobile'

    4.

    字符 ? 表明它前面的分组在这个模式中是可选的

    你可以认为?是在说,“匹配这个问号之前的分组零次或一次”。

    5.

    *(称为星号)意味着“匹配零次或多次”,即星号之前的分组,可以在文本中出现任意次。它可以完全不存在,或一次又一次地重复。

    6.

    意味着“匹配零次或多次”,+(加号)则意味着“匹配一次或多次”。星号不要求分组出现在匹配的字符串中,但加号不同,加号前面的分组必须“至少出现一次”。这不是可选的。

    7.

    如果想要一个分组重复特定次数,就在正则表达式中该分组的后面,跟上花括号包围的数字。例如,正则表达式(Ha){3}将匹配字符串'HaHaHa',但不会匹配'HaHa',因为后者只重复了(Ha)分组两次。 除了一个数字,还可以指定一个范围,即在花括号中写下一个最小值、一个逗号和一个最大值。

    例如,正则表达式(Ha){3,5}将匹配'HaHaHa'、'HaHaHaHa'和'HaHaHaHaHa'。

    也可以不写花括号中的第一个或第二个数字,不限定最小值或最大值。例如,(Ha){3,}将匹配3次或更多次实例,(Ha){,5}将匹配0到5次实例。

    8.

    Python的正则表达式默认是“贪心”的,这表示在有二义的情况下,它们会尽可能匹配最长的字符串。

    花括号的“非贪心”版本匹配尽可能最短的字符串,即在结束的花括号后跟着一个问号。

    9.

    请注意,问号在正则表达式中可能有两种含义:声明非贪心匹配或表示可选的分组。这两种含义是完全无关的。

    10.

    字符分类[0-5]只匹配数字0到5,这比输入(0|1|2|3|4|5)要短很多。

    你可以用方括号定义自己的字符分类。例如,字符分类[aeiouAEIOU]将匹配所有元音字符,不论大小写。

    也可以使用短横表示字母或数字的范围。例如,字符分类[a-zA-Z0-9]将匹配所有小写字母、大写字母和数字。

    请注意,在方括号内,普通的正则表达式符号不会被解释。这意味着,你不需要前面加上倒斜杠转义  .(点号) 、* (星号)、?(问号)或()(左右括号)字符。

    通过在字符分类的左方括号后加上一个插入字符(^),就可以得到“非字符类”。非字符类将匹配不在这个字符类中的所有字符。--取反

    11.

    可以在正则表达式的开始处使用插入符号(^),表明匹配必须发生在被查找文本开始处。类似地,可以再正则表达式的末尾加上美元符号($),表示该字符串必须以这个正则表达式的模式结束。可以同时使用^和$,表明整个字符串必须匹配该模式,也就是说,只匹配该字符串的某个子集是不够的。

    正则表达式r'\d$'匹配以数字0到9结束的字符串。

    正则表达式r'^\d+$'匹配从开始到结束都是数字的字符串。

    如果使用了^和$,那么整个字符串必须匹配该正则表达式。

    12.

    在正则表达式中,.(句点)字符称为“通配符”。它匹配除了换行之外的所有字符。

    句点字符只匹配一个字符,要匹配真正的句点,就是用倒斜杠转义。

    可以用点-星(.*)表示“任意文本”。回忆一下,句点字符表示“除换行外所有单个字符”,星号字符表示“前面字符出现零次或多次”。

    点-星使用“贪心”模式:它总是匹配尽可能多的文本。要用“非贪心”模式匹配所有文本,就使用点-星和问号。像和大括号一起使用时那样,问号告诉Python用非贪心模式匹配。

    点-星将匹配除换行外的所有字符。通过传入re.DOTALL作为re.compile()的第二个参数,可以让句点字符匹配所有字符,包括换行字符。

    13.

    要让正则表达式不区分大小写,可以向re.compile()传入re.IGNORECASE或re.I,作为第二个参数。

    14.

    正则表达式不仅能找到文本模式,而且能够用新的文本替换掉这些模式。Regex对象的sub()方法需要传入两个参数。第一个参数是一个字符串,用于取代发现的匹配。第二个参数是一个字符串,即正则表达式。sub()方法返回替换完成后的字符串。

    >>> namesRegex = re.compile(r'Agent \w+')

    >>> namesRegex.sub('CENSORED', 'Agent Alice gave the secret documents to Agent Bob.')

    'CENSORED gave the secret documents to CENSORED.'

    有时候,你可能需要使用匹配的文本本身,作为替换的一部分。在sub()的第一个参数中,可以输入\1、\2、\3……。表示“在替换中输入分组1、2、3……的文本”。 例如,假定想要隐去密探的姓名,只显示他们姓名的第一个字母。要做到这一点,可以使用正则表达式Agent (\w)\w,传入r'\1*'作为sub()的第一个参数。

    字符串中的\1将由分组1匹配的文本所替代,也就是正则表达式的(\w)分组。 

    >>> agentNamesRegex = re.compile(r'Agent (\w)\w*')

    >>> agentNamesRegex.sub(r'\1****', 'Agent Alice told Agent Carol that Agent

        Eve knew Agent Bob was a double agent.')

    A**** told C**** that E**** knew B**** was a double agent.'

    15.

    如果要匹配的文本模式很简单,正则表达式就很好。但匹配复杂的文本模式,可能需要长的、费解的正则表达式。你可以告诉re.compile(),忽略正则表达式字符串中的空白符和注释,从而缓解这一点。要实现这种详细模式,可以向re.compile()传入变量re.VERBOSE,作为第二个参数。

    16.

    如果要匹配的文本模式很简单,正则表达式就很好。但匹配复杂的文本模式,可能需要长的、费解的正则表达式。

    你可以告诉re.compile(),忽略正则表达式字符串中的空白符和注释,从而缓解这一点。要实现这种详细模式,可以向re.compile()传入变量re.VERBOSE,作为第二个参数。

    phoneRegex = re.compile(r'''(

        (\d{3}|\(\d{3}\))?              # area code

        (\s|-|\.)?                      # separator

        \d{3}                            # first 3 digits

        (\s|-|\.)                        # separator

        \d{4}                            # last 4 digits

        (\s*(ext|x|ext.)\s*\d{2,5})?    # extension

    )''',re.VERBOSE)

    请注意,前面的例子使用了三重引号('"),创建了一个多行字符串。这样就可以将正则表达式定义放在多行中,让它更可读。

    相关文章

      网友评论

          本文标题:正则表达式笔记

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