python专题——正则表达式.doc

python专题——正则表达式.doc

ID:49529831

大小:1.01 MB

页数:15页

时间:2020-03-02

python专题——正则表达式.doc_第1页
python专题——正则表达式.doc_第2页
python专题——正则表达式.doc_第3页
python专题——正则表达式.doc_第4页
python专题——正则表达式.doc_第5页
资源描述:

《python专题——正则表达式.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、.正则表达式正则表达式(RegularExpression)是一种文本模式,包括普通字符和特殊字符。正则表达式使用单个字符串来描述、匹配一系列某个句法规则的字符串。简介为什么使用正则表达式l测试字符串内的模式l替换文本l基于模式匹配从字符串中提取子字符串语法正则表达式(regularexpression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某些子串、将匹配的子串替换或者从某个串中取出符合某个条件的子串等。普通字符普通字符包括没有显示指定为元字符(特殊字符和符号)的所有可打印和不可打印字符,这

2、包括所有大写和小写字母、所有数字、所有标点符号和一些其他字符。非打印字符特殊字符所谓特殊字符,就是一些含有特殊含义的字符。许多元字符要求在试图匹配它们时特word范文.别对待。若要匹配这些特殊字符,必须首先使用字符“转义”,即,将反斜杠“”放在它们前面。限定符限定符用来指定正则表达式的一个给定组件必须要出现多少次才能满足匹配。l“*”匹配前面的子表达式零次或多次,例如/zo*/,匹配“*”前的字符“o”word范文.零次或多次,匹配“z”时匹配了“*”前的子表达式“o”是零次。l*、+和?限定符都是贪婪的,因为它们会尽可能多

3、的匹配文字,只有在它们的后面加上?就可以实现非贪婪或最小匹配。例如:

Chapter1-介绍正则表达式

贪婪模式:下面的表达式匹配从开始小于符号(<)到关闭H1标记的大于符号(>)之间的所有内容。/<.*>/,贪婪模式匹配结果:

Chapter1-介绍正则表达式

非贪婪:如果您只需要匹配开始和介绍H1标记,下面的非贪婪表达式只匹配

。/<.*?>/,非贪婪只会匹配:

定位符定位符能够将正则表达式固定到行首或行尾。注意:l不能讲限定符与定位点一起使用。不允许诸如^*之类的表达式。l若要匹配

4、一行文本开始处的文本,在正则表达式的开始使用^字符。l若要匹配一行文本的结束处的文本,在正则表达式的结束处使用$字符。例如:/^Chapter[1-9][0-9]{0,1}$/字边界是单词和空格之间的位置。非字边界是任何其他位置。下面的表达式匹配单词Chapter的开头三个字符,因为这三个字符出现在字边界的后面:/bCha/b字符的位置是非常重要的。如果它位于匹配字符串的开始,它在单词开始处查找匹配项。如果位于字符串的结尾,他在单词的结尾处查找匹配项。ter/bword范文.下面的表达式匹配Chapter中的字符串ap

5、t,但不匹配aptitude中的字符串apt:/Bapt/选择用圆括号将所有选择项括起来,相邻的选择项之间用

6、分隔。但圆括号会有一个副作用,是相关的匹配会被缓存,此时可用?:放在第一个选项前来消除这种副作用。其中?:是非捕获元之一,还有两个非捕获元是?=和?!,这两个还有更多的含义,前者为正向预查,在任何开始匹配圆括号内的正则表达式模式的位置来匹配搜索字符串,后者为负向预查,在任何开始不匹配该正则表达式模式的位置来匹配搜索字符串。反向引用对一个正则表达式模式或部分模式两边添加圆括号将导致相关匹配存储到一个临时缓冲区中,所捕获

7、的每个子匹配都按照在正则表达式模式中从左到右出现的顺序存储。缓冲区编号从1开始,最多可存储99个捕获的子表达式。每个缓冲区都可以使用 访问,其中n为一个标识特定缓冲区的一位或两位十进制数。可以使用非捕获元字符 ?:、?= 或 ?! 来重写捕获,忽略对相关匹配的保存。例如:varstr="Isisthecostofofgasolinegoingupup";varpatt1=/b([a-z]+)1b/;document.write(str.match(patt1));捕获的表达式,正如[a-z]+指定的,包括一个或多个字

8、母。正则表达式的第二部分是对以前捕获的子匹配项的引用,即,单词的第二个匹配项正好由括号表达式匹配。1指定第一个子匹配项。字边界元字符确保只检测整个单词。否则,诸如"isissued"或"thisis"之类的词组将不能正确地被此表达式识别。正则表达式后面的全局标记g指定将该表达式应用到输入字符串中能够查找到的尽可能多的匹配。表达式的结尾处的不区分大小写i标记指定不区分大小写。多行标记指定换行符的两边可能出现潜在的匹配。组(?P)?P代表的是Python的语法扩展,代表自定义命名,...代表命名的语法wo

9、rd范文.规则。比如:(?Pd+),命名之后可以在后面调用。比如:re.findall(r'(?Pd+)[a-z]+(?P=num)',s)#找出中间夹有字母的数字。元字符word范文.word范文.word范文.运算符优先级匹配规则基本模式匹配模式

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。