正则表达式模式提取大括号之间的字符串并排除大括号 [英] Regex pattern extract string between curly braces and exclude curly braces

查看:38
本文介绍了正则表达式模式提取大括号之间的字符串并排除大括号的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

$str='add[sometext]{egin{equation}label{eqn:3}
f_{1} =
egin{cases}}
eta_{1} + eta_{2}f_{2} & f_{2}leq gamma\
eta_{1} + eta_{2}gamma + eta_{4}(f_{2}-gamma) & f_{2} >gamma
end{cases}sdsdssd,
end{equation}}
 it may have some extra code here with {}
 end{equation}}'

我需要提取add[sometext]{}之间的字符串(即直到添加标签末尾大括号为止)add[sometext]{}之间的字符串可能会有所不同,因此我不能在正则表达式模式中指定这些字符串,我应该只考虑从add[sometext]

的大括号开始和结束

预期输出:

egin{equation}label{eqn:3}
    f_{1} =
    egin{cases}
    eta_{1} + eta_{2}f_{2} & f_{2}leq gamma\
    eta_{1} + eta_{2}gamma + eta_{4}(f_{2}-gamma) & f_{2} >gamma
    end{cases}sdsdssd,
    end{equation}

我已尝试:

$str=preg_replace('/\\adds*[s*w*]s*{(.*?)}/s,$1,$match)

我不知道如何获取相关的大括号(即add tag start { till end })

推荐答案

我有一个符合我的要求的正则表达式。

$str = preg_replace('/\\adds*[.*]s*{(.*?)\\end{(.[^s]*?)}}/s', "$1\end{$2}", $str);

Working demo

这篇关于正则表达式模式提取大括号之间的字符串并排除大括号的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆