一、提取()中的内容
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.正则匹配串里的()是为了提取整个正则串中符合括号里的正则的内容
.是为了表示除了换行符的任一字符。*克林闭包,出现0次或无限次。
加了?是最小匹配,不加是贪婪匹配。
re.S是为了让.表示除了换行符的任一字符。
二、提取[]方括号中的内容
Modifications = 'Q9P2E9 1xPhospho [T225]; 1xPhospho [T466]; 1xPhospho [T717]'
pro, pho = Modifications.split(" ", 1)
res = re.findall(r'\[(.*?)\]',pho)
print(pho)
print(res)
输出:
1xPhospho [T225]; 1xPhospho [T466]; 1xPhospho [T717]
['T225', 'T466', 'T717']
PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:
JavaScript正则表达式在线测试工具: http://tools.jb51.net/regex/javascript
正则表达式在线生成工具: http://tools.jb51.net/regex/create_reg
更多关于Python相关内容可查看本站专题:《Python正则表达式用法总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》