- 1、本文档共17页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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 \
您可能关注的文档
- M1U2_Reading_知识点.ppt
- M1U2_Reading课件.ppt
- M1U2外研社英语九年级 the grand canyon was not just big.ppt
- M1U3 Dying to be thin—Project 牛津高中英语模块一.ppt
- M1U3 Looking good教案2015。10.doc
- M1U3 Dying to be thin 牛津高中英语模块一.ppt
- M1U3Language points 详解 牛津模块一Unit 3.ppt
- [Linux教程 李明 沈超 兄弟连]10.3.1 Shell基础-Bash基本功能-历史命令与补全.ppt
- [Linux教程 李明 沈超 兄弟连]10.3.3 Shell基础-Bash基本功能-输入输出重定向.ppt
- [Linux教程 李明 沈超 兄弟连]10.4.1 Shell基础-Bash变量-用户自定义变量.ppt
- 2024高考物理一轮复习规范演练7共点力的平衡含解析新人教版.doc
- 高中语文第5课苏轼词两首学案3新人教版必修4.doc
- 2024_2025学年高中英语课时分层作业9Unit3LifeinthefutureSectionⅢⅣ含解析新人教版必修5.doc
- 2024_2025学年新教材高中英语模块素养检测含解析译林版必修第一册.doc
- 2024_2025学年新教材高中英语单元综合检测5含解析外研版选择性必修第一册.doc
- 2024高考政治一轮复习第1单元生活与消费第三课多彩的消费练习含解析新人教版必修1.doc
- 2024_2025学年新教材高中英语WELCOMEUNITSectionⅡReadingandThi.doc
- 2024_2025学年高中历史专题九当今世界政治格局的多极化趋势测评含解析人民版必修1.docx
- 2024高考生物一轮复习第9单元生物与环境第29讲生态系统的结构和功能教案.docx
- 2024_2025学年新教材高中英语UNIT5LANGUAGESAROUNDTHEWORLDSect.doc
最近下载
- 会计学原理23版 英文版课件WildFAP23eCh05PPT.pptx
- 华为公司职类职种职级体系的划分及职业发展通道设计.pdf VIP
- 建筑解析流水别墅.pptx
- 2025届高三英语复习语法填空专题(24张PPT).pptx VIP
- 基于PLC的磨矿控制系统设计.docx
- 有限元分析论文.doc VIP
- 苏教版小学科学五年级上册第四单元《水在自然界的循环》大单元教学设计(含练习).docx
- 聚氯乙烯热收缩膜标签验收标准.doc VIP
- 2023年安徽省高中学业水平合格性考试数学试卷真题(含答案详解) (2).pdf VIP
- 2025届江苏省南菁高级中学物理高一第一学期期中达标检测模拟试题含解析.doc
文档评论(0)