正则表达式
RE

正则表达式

动机

  1. 文本处理已经成为计算机常见工作之一
  2. 对文本内容的搜索,定位,提取是逻辑比较复杂的工作
  3. 为了快速方便的解决上述问题,产生了正则表达式技术

简介

  1. 定义

即文本的高级匹配模式,提供搜索,替换等功能。其本质是由一系列字符和特殊符号构成的字串,这个字串即正则表达式。

  1. 原理

通过普通字符和有特定含义的字符,来组成字符串,用以描述一定的字符串规则,比如:重复,位置等,来表达某类特定的字符串,进而匹配。

  1. 目标
  • 熟练掌握正则表达式元字符
  • 能够读懂常用正则表达式,编辑简单的正则规则
  • 能够数量使用re模块操作正则表达式

元字符使用

普通字符

  • 匹配规则:每个普通字符匹配其对应的字符
  • 注意事项:正则表达式在python中也可以匹配中文

或关系ß

  • 元字符: |
  • 匹配规则: 匹配 | 两侧任意的正则表达式即可

匹配单个字符

  • 元字符: .
  • 匹配规则:匹配除换行外的任意一个字符

匹配字符集

  • 元字符: [字符集]
  • 匹配规则: 匹配字符集中的任意一个字符
  • 表达形式:

[abc#!好] 表示 [] 中的任意一个字符 [0-9],[a-z],[A-Z] 表示区间内的任意一个字符 [_#?0-9a-z] 混合书写,一般区间表达写在后面

匹配字符集反集

  • 元字符:[^字符集]
  • 匹配规则:匹配除了字符集以外的任意一个字符

匹配字符串开始位置

  • 元字符: ^
  • 匹配规则:匹配目标字符串的开头位置

匹配字符串的结束位置

  • 元字符: $
  • 匹配规则: 匹配目标字符串的结尾位置
  • 规则技巧: ^ 和 $必然出现在正则表达式的开头和结尾处。如果两则同时出现,则中间的部分必须匹配整个目标字符串的全部内容。

匹配字符重复

  • 元字符: *
  • 匹配规则:匹配前面的字符出现0次或多次

  • 元字符:+
  • 匹配规则: 匹配前面的字符出现1次或多次

  • 元字符:?
  • 匹配规则: 匹配前面的字符出现0次或1次

  • 元字符:{n}
  • 匹配规则: 匹配前面的字符出现n次

  • 元字符:{m,n}
  • 匹配规则: 匹配前面的字符出现m-n次

匹配任意(非)数字字符

  • 元字符: \d \D
  • 匹配规则:\d 匹配任意数字字符,\D 匹配任意非数字字符

匹配任意(非)普通字符

  • 元字符: \w \W
  • 匹配规则: \w 匹配普通字符,\W 匹配非普通字符
  • 说明: 普通字符指数字,字母,下划线,汉字。

匹配任意(非)空字符

  • 元字符: \s \S
  • 匹配规则: \s 匹配空字符,\S 匹配非空字符
  • 说明:空字符指 空格 \r \n \t \v \f 字符

匹配开头结尾位置

  • 元字符: \A \Z
  • 匹配规则: \A 表示开头位置,\Z 表示结尾位置

匹配(非)单词的边界位置

  • 元字符: \b \B
  • 匹配规则: \b 表示单词边界,\B 表示非单词边界
  • 说明:单词边界指数字字母(汉字)下划线与其他字符的交界位置。
类别元字符
匹配字符. […] [^…] \d \D \w \W \s \S
匹配重复* + ? {n} {m,n}
匹配位置^ $ \A \Z \b \B
其他| () \

正则表达式的转义

  1. 如果使用正则表达式匹配特殊字符则需要加 \ 表示转义。

特殊字符: . * + ? ^ $ [] () {} | \

  1. 在编程语言中,常使用原生字符串书写正则表达式避免多重转义的麻烦。

贪婪模式和非贪婪模式

  1. 定义

贪婪模式: 默认情况下,匹配重复的元字符总是尽可能多的向后匹配内容。比如: * + ? {m,n}

非贪婪模式(懒惰模式): 让匹配重复的元字符尽可能少的向后匹配内容。

  1. 贪婪模式转换为非贪婪模式
  • 在匹配重复元字符后加 '?' 号即可

正则表达式分组

  1. 定义

在正则表达式中,以()建立正则表达式的内部分组,子组是正则表达式的一部分,可以作为内部整体操作对象。

  1. 作用
  • 可以被作为整体操作,改变元字符的操作对象
  • 可以通过编程语言某些接口获取匹配内容中,子组对应的内容部分
  1. 捕获组

可以给正则表达式的子组起一个名字,表达该子组的意义。这种有名称的子组即为捕获组。

格式:(?P<name>pattern)

  1. 注意事项
  • 一个正则表达式中可以包含多个子组
  • 子组可以嵌套,但是不要重叠或者嵌套结构复杂
  • 子组序列号一般从外到内,从左到右计数

分组

正则表达式匹配原则

  1. 正确性,能够正确的匹配出目标字符串.
  2. 排他性,除了目标字符串之外尽可能少的匹配其他内容.
  3. 全面性,尽可能考虑到目标字符串的所有情况,不遗漏.

Python re模块使用

参考代码re/regex.py








参考代码re/regex1.py





compile对象属性


match对象的属性方法

参考代码re/regex2.py

  1. 属性变量
  • pos 匹配的目标字符串开始位置
  • endpos 匹配的目标字符串结束位置
  • re 正则表达式
  • string 目标字符串
  • lastgroup 最后一组的名称
  • lastindex 最后一组的序号
  1. 属性方法
  • span() 获取匹配内容的起止位置

  • start() 获取匹配内容的开始位置

  • end() 获取匹配内容的结束位置

  • groupdict() 获取捕获组字典,组名为键,对应内容为值

  • groups() 获取子组对应内容

  • group(n = 0)

    功能:获取match对象匹配内容 参数:默认为0表示获取整个match对象内容,如果是序列号或者组名则表示获取对应子组内容 返回值:匹配字符串

结构

flags参数扩展

参考代码re/flags.py

  1. 使用函数:re模块调用的匹配函数。如:re.compile,re.findall,re.search….
  2. 作用:扩展丰富正则表达式的匹配功能
  3. 常用flag

A == ASCII 元字符只能匹配ascii码

I == IGNORECASE 匹配忽略字母大小写

S == DOTALL 使 . 可以匹配换行

M == MULTILINE 使 ^ $可以匹配每一行的开头结尾位置

X == VERBOSE 为正则添加注释

  1. 使用多个flag

    方法:使用按位或连接
    e.g. : flags = re.I | re.A

 

 

暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇