python递归
在 Python 中实现递归正则表达式匹配,? 例如:
1. 如何编写匹配括号平衡字符串的表达式,如"foo(bar(bar(foo)))(foo1)bar1"
2. 提取aw函数参数,但是传参数比较复杂的场景;def func(a=10, b=100)
func(a=[(10+ 15) - 15*3], b=[(3 * 2 -6) * (3 - 2) * (1+(10+1))])
提取原有的入参值a =?[(10+ 15) - 15*3]?和 b=?[(3 * 2 -6) * (3 - 2) * (1+(10+1))]
默认的正则表达式,通过re,在python中可能是不支持递归正则的。不过有一个其它的库pyparsing可以实现
#!/usr/bin/env python
from pyparsing import nestedExpr
import sys
astring=sys.argv[1]
if not astring.startswith('('):
astring='('+astring+')'
expr = nestedExpr('(', ')')
result=expr.parseString(astring).asList()[0]
print(result)
运行它会产生:
% test.py "foo(bar(bar(foo)))(foo1)bar1"
['foo', ['bar', ['bar', ['foo']]], ['foo1'], 'bar1']