专栏中心

EEPW首页 > 专栏 > 扣丁学堂Python基础教程之正则表达式及实例代码

扣丁学堂Python基础教程之正则表达式及实例代码

发布人:扣丁学堂 时间:2020-06-23 来源:工程师 发布文章

  今天扣丁学堂给大家介绍一下关于Python视频教程之正则表达式的介绍,首先正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。Python自1.5版本起增加了re模块,它提供Perl风格的正则表达式模式。

2.jpg

  re模块使Python语言拥有全部的正则表达式功能,compile函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。


  re模块也提供了与这些方法功能完全一致的函数,这些函数使用一个模式字符串做为它们的第一个参数。下面主要介绍Python中常用的正则表达式处理函数。


  re.match函数


  re.match尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none。


  函数语法:


  re.match(pattern,string,flags=0)


  函数参数说明:


  参数描述


  pattern匹配的正则表达式


  string要匹配的字符串。


  flags标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。


  匹配成功re.match方法返回一个匹配的对象,否则返回None。


  我们可以使用group(num)或groups()匹配对象函数来获取匹配表达式。


  匹配对象方法描述


  group(num=0)匹配的整个表达式的字符串,group()可以一次输入多个组号,在这种情况下它将返回一个包含那些组所对应值的元组。


  groups()返回一个包含所有小组字符串的元组,从1到所含的小组号。


  实例1


  #!/usr/bin/python#-*-coding:UTF-8-*-importreprint(re.match('www','www.runoob.com').span())#在起始位置匹配print(re.match('com','www.runoob.com'))#不在起始位置匹配


  以上实例运行输出结果为:


  (0,3)


  None


  实例2


  #!/usr/bin/pythonimportreline="Catsaresmarterthandogs"matchObj=re.match(r'(.*)are(.*?).*',line,re.M|re.I)ifmatchObj:print"matchObj.group():",matchObj.group()print"matchObj.group(1):",matchObj.group(1)print"matchObj.group(2):",matchObj.group(2)else:print"Nomatch!!"


  以上实例执行结果如下:


  matchObj.group():Catsaresmarterthandogs


  matchObj.group(1):Cats


  matchObj.group(2):smarter


  re.search方法


  re.search扫描整个字符串并返回第一个成功的匹配。


  函数语法:


  re.search(pattern,string,flags=0)


  函数参数说明:


  参数描述


  pattern匹配的正则表达式


  string要匹配的字符串。


  flags标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。


  匹配成功re.search方法返回一个匹配的对象,否则返回None。


  我们可以使用group(num)或groups()匹配对象函数来获取匹配表达式。


  匹配对象方法描述


  group(num=0)匹配的整个表达式的字符串,group()可以一次输入多个组号,在这种情况下它将返回一个包含那些组所对应值的元组。


  groups()返回一个包含所有小组字符串的元组,从1到所含的小组号。


  实例1


  #!/usr/bin/python#-*-coding:UTF-8-*-importreprint(re.search('www','www.runoob.com').span())#在起始位置匹配print(re.search('com','www.runoob.com').span())#不在起始位置匹配


  以上实例运行输出结果为:


  (0,3)


  (11,14)


  实例2


  #!/usr/bin/pythonimportreline="Catsaresmarterthandogs";searchObj=re.search(r'(.*)are(.*?).*',line,re.M|re.I)ifsearchObj:print"searchObj.group():",searchObj.group()print"searchObj.group(1):",searchObj.group(1)print"searchObj.group(2):",searchObj.group(2)else:print"Nothingfound!!"以上实例执行结果如下:


  searchObj.group():Catsaresmarterthandogs


  searchObj.group(1):Cats


  searchObj.group(2):smarter


  re.match与re.search的区别


  re.match只匹配字符串的开始,如果字符串开始不符合正则表达式,则匹配失败,函数返回None;而re.search匹配整个字符串,直到找到一个匹配。


  实例


  #!/usr/bin/pythonimportreline="Catsaresmarterthandogs";matchObj=re.match(r'dogs',line,re.M|re.I)ifmatchObj:print"match-->matchObj.group():",matchObj.group()else:print"Nomatch!!"matchObj=re.search(r'dogs',line,re.M|re.I)ifmatchObj:print"search-->matchObj.group():",matchObj.group()else:print"Nomatch!!"以上实例运行结果如下:


  Nomatch!!


  search-->matchObj.group():dogs


  检索和替换


  Python的re模块提供了re.sub用于替换字符串中的匹配项。


  语法:


  re.sub(pattern,repl,string,count=0,flags=0)


  参数:


  pattern:正则中的模式字符串。


  repl:替换的字符串,也可为一个函数。


  string:要被查找替换的原始字符串。


  count:模式匹配后替换的最大次数,默认0表示替换所有的匹配。


  实例


  #!/usr/bin/python#-*-coding:UTF-8-*-importrephone="2004-959-559#这是一个国外电话号码"#删除字符串中的Python注释num=re.sub(r'#.*$',"",phone)print"电话号码是:",num#删除非数字(-)的字符串num=re.sub(r'\D',"",phone)print"电话号码是:",num以上实例执行结果如下:


  电话号码是:2004-959-559


  电话号码是:2004959559


  repl参数是一个函数


  以下实例中将字符串中的匹配的数字乘于2:


  实例


  #!/usr/bin/python#-*-coding:UTF-8-*-importre#将匹配的数字乘于2defdouble(matched):value=int(matched.group('value'))returnstr(value*2)s='A23G4HFD567'print(re.sub('(?P\d+)',double,s))


  执行输出结果为:


  A46G8HFD1134


  正则表达式修饰符-可选标志


  正则表达式可以包含一些可选标志修饰符来控制匹配的模式。修饰符被指定为一个可选的标志。多个标志可以通过按位OR(|)它们来指定。如re.I|re.M被设置成I和M标志:


  修饰符描述


  re.I使匹配对大小写不敏感


  re.L做本地化识别(locale-aware)匹配


  re.M多行匹配,影响^和$


  re.S使.匹配包括换行在内的所有字符


  re.U根据Unicode字符集解析字符。这个标志影响\w,\W,\b,\B.


  re.X该标志通过给予你更灵活的格式以便你将正则表达式写得更易于理解。


  正则表达式模式


  模式字符串使用特殊的语法来表示一个正则表达式:


  字母和数字表示他们自身。一个正则表达式模式中的字母和数字匹配同样的字符串。


  多数字母和数字前加一个反斜杠时会拥有不同的含义。


  标点符号只有被转义时才匹配自身,否则它们表示特殊的含义。


  反斜杠本身需要使用反斜杠转义。


  由于正则表达式通常都包含反斜杠,所以你最好使用原始字符串来表示它们。模式元素(如r'\t',等价于'\\t')匹配相应的特殊字符。


  下表列出了正则表达式模式语法中的特殊元素。如果你使用模式的同时提供了可选的标志参数,某些模式元素的含义会改变。


  ^匹配字符串的开头


  $匹配字符串的末尾。


  .匹配任意字符,除了换行符,当re.DOTALL标记被指定时,则可以匹配包括换行符的任意字符。


  [...]用来表示一组字符,单独列出:[amk]匹配'a','m'或'k'


  [^...]不在[]中的字符:[^abc]匹配除了a,b,c之外的字符。


  re*匹配0个或多个的表达式。


  re+匹配1个或多个的表达式。


  re?匹配0个或1个由前面的正则表达式定义的片段,非贪婪方式


  re{n}


  re{n,}精确匹配n个前面表达式。


  re{n,m}匹配n到m次由前面的正则表达式定义的片段,贪婪方式


  a|b匹配a或b


  (re)G匹配括号内的表达式,也表示一个组


  (?imx)正则表达式包含三种可选标志:i,m,或x。只影响括号中的区域。


  (?-imx)正则表达式关闭i,m,或x可选标志。只影响括号中的区域。


  (?:re)类似(...),但是不表示一个组


  (?imx:re)在括号中使用i,m,或x可选标志


  (?-imx:re)在括号中不使用i,m,或x可选标志


  (?#...)注释.


  (?=re)前向肯定界定符。如果所含正则表达式,以...表示,在当前位置成功匹配时成功,否则失败。但一旦所含表达式已经尝试,匹配引擎根本没有提高;模式的剩余部分还要尝试界定符的右边。


  (?!re)前向否定界定符。与肯定界定符相反;当所含表达式不能在字符串当前位置匹配时成功


  (?>re)匹配的独立模式,省去回溯。


  \w匹配字母数字及下划线


  \W匹配非字母数字及下划线


  \s匹配任意空白字符,等价于[\t\n\r\f].


  \S匹配任意非空字符


  \d匹配任意数字,等价于[0-9].


  \D匹配任意非数字


  \A匹配字符串开始


  \Z匹配字符串结束,如果是存在换行,只匹配到换行前的结束字符串。c


  \z匹配字符串结束


  \G匹配最后匹配完成的位置。


  \b匹配一个单词边界,也就是指单词和空格间的位置。例如,'er\b'可以匹配"never"中的'er',但不能匹配"verb"中的'er'。


  \B匹配非单词边界。'er\B'能匹配"verb"中的'er',但不能匹配"never"中的'er'。


  \n,\t,等.匹配一个换行符。匹配一个制表符。等


  \1...\9匹配第n个分组的内容。


  \10匹配第n个分组的内容,如果它经匹配。否则指的是八进制字符码的表达式。


  正则表达式实例


  python匹配"python".


  字符类


  [Pp]ython匹配"Python"或"python"


  rub[ye]匹配"ruby"或"rube"


  [aeiou]匹配中括号内的任意一个字母


  [0-9]匹配任何数字。类似于[0123456789]


  [a-z]匹配任何小写字母


  [A-Z]匹配任何大写字母


  [a-zA-Z0-9]匹配任何字母及数字


  [^aeiou]除了aeiou字母以外的所有字符


  [^0-9]匹配除了数字外的字符


  特殊字符类


  .匹配除"\n"之外的任何单个字符。要匹配包括'\n'在内的任何字符,请使用象'[.\n]'的模式。


  \d匹配一个数字字符。等价于[0-9]。


  \D匹配一个非数字字符。等价于[^0-9]。


  \s匹配任何空白字符,包括空格、制表符、换页符等等。等价于[\f\n\r\t\v]。


  \S匹配任何非空白字符。等价于[^\f\n\r\t\v]。


  \w匹配包括下划线的任何单词字符。等价于'[A-Za-z0-9_]'。


  \W匹配任何非单词字符。等价于'[^A-Za-z0-9_]'。


  以上就是关于Python正则表达式的详细介绍,最后想要学习Python开发的小伙伴一定要选择专业的Python培训机构。扣丁学堂作为知名的IT培训机构,不仅有专业的老师和与时俱进的课程体系,还有大量的Python全栈开发工程师视频教程供学员观看学习,想要学好Python开发技术的小伙伴就抓紧时间行动吧。

专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词:

相关推荐

再次超越特斯拉!比亚迪成为2025年一季度纯电全球销冠

TI Smart Motor Driver

视频 2011-11-15

交流电机控制方法及实现

迎接蜕变——谈嵌入式运算核心技术与产业之最新应用

视频 2011-11-04

美光、SK海力士跟随中!三星对内存、闪存产品提价3-5%:客户已开始谈判新合同

飞思卡尔完善的永磁同步电机无位置传感器矢量控制解决方案

中国发布HDMI和DisplayPort替代方案!GPMI接口来了:一根线支持480W供电+192Gbps带宽

网络与存储 2025-04-07

机器人精度大升级!先进的电流和电压检测技术如何助力更精确电机控制?

关税重伤苹果!iPhone恐大涨价:美国门店涌现恐慌性抢购潮

PLL的原理

资源下载 2007-02-09

利用模拟预失真技术实现射频功率放大器线性化

小米新款SoC或采用台积电N4P工艺,图形性能优于第二代骁龙8

中国微特电机行业现状与发展趋势

从零售到航天,边缘AI含金量还在上升

高压摆率负载瞬态测试

工业机器人发展未来何去何从引人深思

机器人 2025-04-07
更多 培训课堂
更多 焦点
更多 视频

技术专区