[Python]网络爬虫(七):Python中的正则表达式教程.docx

[Python]网络爬虫(七):Python中的正则表达式教程.docx

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[Python]网络爬虫(七):Python中的正则表达式教程

一、 正则表达式基础1.1.概念介绍正则表达式是用于处理字符串的强大工具,它并不是Python的一部分。其他编程语言中也有正则表达式的概念,区别只在于不同的编程语言实现支持的语法数量不同。它拥有自己独特的语法以及一个独立的处理引擎,在提供了正则表达式的语言里,正则表达式的语法都是一样的。下图展示了使用正则表达式进行匹配的流程:正则表达式的大致匹配过程是:1.依次拿出表达式和文本中的字符比较,2.如果每一个字符都能匹配,则匹配成功;一旦有匹配不成功的字符则匹配失败。3.如果表达式中有量词或边界,这个过程会稍微有一些不同。下图列出了Python支持的正则表达式元字符和语法:???1.2. 数量词的贪婪模式与非贪婪模式正则表达式通常用于在文本中查找匹配的字符串。贪婪模式,总是尝试匹配尽可能多的字符;非贪婪模式则相反,总是尝试匹配尽可能少的字符。Python里数量词默认是贪婪的。例如:正则表达式ab*如果用于查找abbbc,将找到abbb。而如果使用非贪婪的数量词ab*?,将找到a。1.3. 反斜杠的问题与大多数编程语言相同,正则表达式里使用\作为转义字符,这就可能造成反斜杠困扰。假如你需要匹配文本中的字符\,那么使用编程语言表示的正则表达式里将需要4个反斜杠\\\\:第一个和第三个用于在编程语言里将第二个和第四个转义成反斜杠,转换成两个反斜杠\\后再在正则表达式里转义成一个反斜杠用来匹配反斜杠\。这样显然是非常麻烦的。Python里的原生字符串很好地解决了这个问题,这个例子中的正则表达式可以使用r\\表示。同样,匹配一个数字的\\d可以写成r\d。有了原生字符串,妈妈再也不用担心我的反斜杠问题~二、?介绍re模块2.1.??CompilePython通过re模块提供对正则表达式的支持。使用re的一般步骤是:Step1:先将正则表达式的字符串形式编译为Pattern实例。Step2:然后使用Pattern实例处理文本并获得匹配结果(一个Match实例)。Step3:最后使用Match实例获得信息,进行其他的操作。我们新建一个re01.py来试验一下re的应用:[python]?view plaincopy#?-*-?coding:?utf-8?-*-??#一个简单的re实例,匹配字符串中的hello字符串????#导入re模块??import?re?????#?将正则表达式编译成Pattern对象,注意hello前面的r的意思是“原生字符串”??pattern?=?pile(rhello)?????#?使用Pattern匹配文本,获得匹配结果,无法匹配时将返回None??match1?=?pattern.match(hello?world!)??match2?=?pattern.match(helloo?world!)??match3?=?pattern.match(helllo?world!)????#如果match1匹配成功??if?match1:??????#?使用Match获得分组信息??????print?match1.group()??else:??????print?match1匹配失败!??????#如果match2匹配成功??if?match2:??????#?使用Match获得分组信息??????print?match2.group()??else:??????print?match2匹配失败!??????#如果match3匹配成功??if?match3:??????#?使用Match获得分组信息??????print?match3.group()??else:??????print?match3匹配失败!??可以看到控制台输出了匹配的三个结果:下面来具体看看代码中的关键方法。★ pile(strPattern[, flag]):这个方法是Pattern类的工厂方法,用于将字符串形式的正则表达式编译为Pattern对象。第二个参数flag是匹配模式,取值可以使用按位或运算符|表示同时生效,比如re.I | re.M。另外,你也可以在regex字符串中指定模式,比如pile(pattern, re.I | re.M)与pile((?im)pattern)是等价的。可选值有:??? re.I(全拼:IGNORECASE): 忽略大小写(括号内是完整写法,下同)???re.M(全拼:MULTILINE): 多行模式,改变^和$的行为(参见上图)????re.S(全拼:DOTALL): 点任意匹配模式,改变.的行为????re.L(全拼:LOCALE): 使预定字符类 \w \W \b \B \s \S 取决于当前区域设定????re.U(全拼:UNICODE): 使预定字符类 \w \W \b \B \s \S \d \

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档