本文实例讲述了Python使用re模块正则提取字符串中括号内的内容操作。分享给大家供大家参考,具体如下:
直接上代码吧:
1
2
3
4
5
6
7
8
|
# -*- coding:utf-8 -*-
#! python2
import re
string = 'abe(ac)ad)'
p1 = re. compile (r '[(](.*?)[)]' , re.S) #最小匹配
p2 = re. compile (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是为了让.表示除了换行符的任一字符。
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://blog.csdn.net/your_answer/article/details/80456550