python正则表达式提取括号内的内容-python之re提取字符串中
括号内的内容
python之re提取字符串中括号内的内容
正则表达式获取括号内容代码如下:import re
string = "abe(ac)ad)"
p1 = repile(r"[(](.*?)[)]", re.S) #最⼩匹配
p2 = repile(r"[(](.*)[)]", re.S) #贪婪匹配
print(re.findall(p1, string))
print(re.findall(p2, string)
["ac"]
["ac)ad"]
解释⼀下:
1.正则匹配串前加了r就是为了使得⾥⾯的特殊符号不⽤写反斜杠了。
2.[ ]具有去特殊符号的作⽤,也就是说[(]⾥的(只是平凡的括号
3.正则匹配串⾥的()是为了提取整个正则串中符合括号⾥的正则的内容
4. .是为了表⽰除了换⾏符的任⼀字符。*克林闭包,出现0次或⽆限次。
5. 加了?是最⼩匹配,不加是贪婪匹配。
6. re.S是为了让.表⽰除了换⾏符的任⼀字符。
re.S解释:
re.S表⽰“.”(不包含外侧双引号,下同)的作⽤扩展到整个字符串,包括“ ”
正则表达式中,“.”的作⽤是匹配除“ ”以外的任何字符,也就是说,它是在⼀⾏中进⾏匹配。这⾥的“⾏”是以“ ”进⾏区分的。a字符串有每⾏的末尾有⼀个“ ”,不过它不可见。
如果不使⽤re.S参数,则只在每⼀⾏内进⾏匹配,如果⼀⾏没有,就换下⼀⾏重新开始,不会跨⾏。⽽使⽤re.S参数以后,正则表达式会将这个字符串作为⼀个整体,将“ ”当做⼀个普通的字符加⼊到这个字符串中,在整体中进⾏匹配。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论