正则表达式 – 如何用不支持它们的语言模拟非贪婪量词?

考虑这个正则表达式:<(.*)>

应用此字符串:

<2356> <my pal ned> <!@%@>

显然,由于贪婪*,它将匹配整个字符串.最好的解决方案是使用非贪婪的量词,如* ?.但是,许多语言和编辑都不支持这些.

对于像上面这样的简单案例,我已经用这样的正则表达式解决了这个限制:<([^>] *)>

但是像这样的正则表达式可以做些什么呢?开始(.*)结束

应用此字符串:

start 2356 end start my pal ned end start !@%@ end

有什么办法吗?

解决方法

如果结束条件是单个字符的存在,则可以使用否定字符类:

<([^>]*)>

对于结束条件为多个字符的更复杂情况,您可以尝试使用否定前瞻,但如果不支持延迟匹配,则前瞻的可能性不是:

((?!end).)*

你最后的办法是建造一些像这样可怕的东西:

(en[^d]|e[^n]|[^e])*

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...