在做项目中碰到了一个问题,简单描述就是正则匹配出了一段字符串,现在要对这个字符中中的最外层括号内的内容做修改。
text = 'adfsdfa(asd(da((ss(df())f)()ds()f(d)f))ff)dafa)'
假设第一次正则匹配出的是上面的字符窜,现在要找到第一个左括号的对应右括号。正则真的不知道咋写了,两个括号中的括号数是不确定的,同时也不能保证右括号一定是最后出现的一个。没办法了我只能字符串挨个匹配了,简易代码如下:
text = 'adfsdfa(asd(da((ss(df())f)()ds()f(d)f))ff)dafa)'
index_start = text.find('(')
text_02 = text[index_start:]
index_end = 0
t = 0
while index_end<len(text_02):
if text_02[index_end] == '(':
t +=1
elif text_02[index_end] == ')':
t -= 1
index_end += 1
if t == 0:
break
else:
print('无')
print(text_02[:index_end])
这个逻辑就是t初始值为0,每碰到一个‘(’ t+1 每碰到一个‘)’ t-1 这样成对的括号差值就为1,对这个字符串来说第一个左括号的t值是1,所以与之对应的就是0,故而在0的时候跳出循环。