我有一个正则表达式,旨在匹配特定语法,n次,每次出现后都有一个管道(|),除了最后一次出现。目前,我的模式是沿着(pattern)\|{3}
的路线,但是这不符合没有尾随管道的要求。无论如何,我可以完成这个没有重复(pattern)
?我能想到的最佳解决方案是(pattern)\|{2}(pattern)
。正则表达式:重复模式n次,最终重复的变化
有效实施例:
* | 401 | [2-10]
无效实施例:
* | 401 | [2-10] |
的(pattern)
值是无关的回答我的具体问题,但为了完整起见,在这里它是在其目前的形式:(?:(?:((\*)|(\[[\w+ ]\-[\w+ ]\])|(\d+)))\|){3}
编辑
这是正在内.NET消耗, JavaScript的。
你能提供一个真实的例子吗? – 2014-12-19 01:01:45
同样,我不认为这对于实际问题来说是非常关键的,但是这将是一个有效输入的例子:'[1-2] | * | 254' – 2014-12-19 01:03:03
'我能想到的最好的解决方案是)\ | {2}(pattern)。“在我看来,这是最好的解决方案 - 您不必关心处理不匹配的模式和分隔符的数量。为了防止重复,只需使用字符串连接来构建模式。 – nhahtdh 2014-12-19 02:17:34