关于模式匹配与正则表达式几个例子,分享如下:
#正则表达式实践
import re
"""
#匹配Regex对象
PhoneNumRegex=re.compile(r'\d\d\d-\d\d\d-\d\d\d\d')
mo=PhoneNumRegex.search('My number is 615-555-4242.')
print('Phone number found:'+mo.group())
"""
#利用括号分组
PhoneNumRegex=re.compile(r'(\d\d\d)-(\d\d\d-\d\d\d\d)')
mo=PhoneNumRegex.search('My number is 815-565-7272')
print(mo.group(1))
print(mo.group(2))
print(mo.group(0))
print(mo.groups())
#用管道匹配多个分组 第一次出现的匹配文本将作为Match对象返回
heroRegex=re.compile(r'Batman|Tina Fey')
mo1=heroRegex.search('Batman and Tina Fey.')
print(mo1.group())
mo2=heroRegex.search(' Tina Fey and Batman.')
print(mo2.group())
batRegex=re.compile(r'Bat(man|mobile|copter|bat)')
mo3=batRegex.search('Batmobile lost a wheel')
print(mo3.group())
print(mo3.group(0))
print(mo3.group(1))
#用问号实现可选匹配 字符?表明它前面的分组在这个模式中时可选的
#以下例子中,正则表达式匹配的文本中,wo将出现零次或一次
batRegexDemo=re.compile(r'Bat(wo)?man')
mo4=batRegexDemo.search('The Adventures of Batman')
print('正则表达式匹配的文本中,wo后接?将出现零次或一次'+mo4.group())
mo5=batRegexDemo.search('The Adventures of Batwoman')
print('正则表达式匹配的文本中,wo后接?将出现零次或一次'+mo5.group())
#用星号匹配零次或多次
batRegexDemo1=re.compile(r'Bat(wo)*man')
mo6=batRegexDemo1.search('The Adventures of Batman')
print('正则表达式匹配的文本中,wo后接*将出现零次或多次'+mo6.group())
mo55=batRegexDemo1.search('The Adventures of Batwoman')
print('正则表达式匹配的文本中,wo后接*将出现零次或多次'+mo55.group())
mo7=batRegexDemo1.search('The Adventures of Batwowowowoman')
print('正则表达式匹配的文本中,wo后接*将出现零次或多次'+mo7.group())
#用花括号匹配特定次数
haRegex=re.compile(r'(Ha){3}')
mo8=haRegex.search('HaHaHaWOWOWOEWJRHaHa')
print('用花括号{}匹配特定次数'+mo8.group())
mo9=haRegex.search('Ha')
print(mo9==None)