import re
表示或者C D都可以匹配
re.search(r'Fish(C|D)',"FishC")
re.search(r'Fish(C|D)',"FishD")
'^'这个是作为字符串的开头
'$'这个是作为字符串的结尾
>>> import re
>>> re.search(r'^FishC','FishC.com')
<re.Match object; span=(0, 5), match='FishC'>
>>> re.search(r'FishC$','I lover FishC')
<re.Match object; span=(8, 13), match='FishC'>
''可以将一个普通字符变为特殊字符
也可以解除元字符的特殊功能
引用序号对应的子组所匹配的字符串
三位竖的序号表示八进制的阿斯克码所对应的字符
re.search(r'(Fish)\1','FishFish')
re.search(r'(Fish)\141','Fisha')
[.]
re.search(r'[.]','Fisha.Fish')
re.findall(r'[a-z]','Fisha.Fish')
re.findall(r'[^a-z]','Fisha.Fish')#表示取反
{}表示匹配的次数或者范围
re.search(r'(FishC){3}','FishCFishCFishC')
re.search(r'(FishC){1,5}','FishCFishCFishC')#一次到五次之间
'*'匹配前面的子表达式0次或者多次,等价于{0,}
'+'匹配前面的子表达式1次或者多次,等价于{1,}
'?'匹配前面的子表达式0次或者1次,等价于{0,1}
re.search(r'(FishC)*','FishCFishCFishC')
\A 匹配输入字符串的开始位置,参考’^’
\Z 匹配输入字符串的结束位置,参考’$’
\b 匹配一单词边界,下横线不算隔开单词,只有在字符类中表示退格
re.search(r'\bfish\b','love fish love_fish,fish')
re.findall(r'\bfish\b','love fish love_fish,fish')
\b 匹配非单词边界,与b相反的
re.findall(r'fish\B','love fish1 love_fish,fish')
re.findall(r'\w','我爱与此工作室 (love_fishC)')
['我', '爱', '与', '此', '工', '作', '室', 'l', 'o', 'v', 'e', '_', 'f', 'i', 's', 'h', 'C']
p = re.compile(r'[A-Z]')
type(p)
<class 're.Pattern'>
p.findall('I love_fishC')
['I', 'C']
VERBOSE 可以让正则表达式有空格和换行,更加容易读
search()方法
result = re.search(r'fish\B','love fish1 love_fish,fish')
result.group()
result.end#结束位置
result.start#开始位置
findall()方法