我已经研究了几个类似我的问题,但似乎找不出一个。顾名思义,我需要解决以下几个问题:
除"/screens/company-setup-details".外,排除以"/screens“开头的所有页面
到目前为止,我一直试图在http://regexr.com上构建这个程序,但没有取得任何进展。我觉得这是一个简单的解决方案,但我很难找到广泛的排除和小范围的包容。
我想补充一下,其中的一些例子是:"/screens/home“、"/screens/login”和“/screens/embed”。
发布于 2015-02-26 03:37:38
^/(?!screens(?!/company-setup-details))排除以/screens开头的所有路径,但后面是/company-setup-details的路径除外。
解释:,它是双重否定逻辑。对于第一个负前瞻到" pass“(即不匹配),则其内部的负前瞻性也必须通过(不匹配)。
请注意,上面的表达式将匹配:
/screens开头的路径/screens/company-setup-details开头的路径如果您希望只匹配忽略的路径,则使用:
^/(screens(?!/company-setup-details))更新: GA regexp自2009年以来不再支持负前瞻性,因此我的上述表达式将无法工作。不过,这是一个丑陋的黑客,它应该能胜任这项工作:
^/(?:(?:[^s]|$)|s(?:[^c]|$)|sc(?:[^r]|$)|scr(?:[^e]|$)|scre(?:[^e]|$)|scree(?:[^n]|$)|screen(?:[^s]|$)|screens/company-setup-details)雷杰克斯。
如果您不介意排除screens的引子串的路径(例如,如果整个路径是/scr或/scree),那么您可以简化一下regexp:
^/(?:[^s]|s[^c]|sc[^r]|scr[^e]|scre[^e]|scree[^n]|screen[^s]|screens/company-setup-details)雷杰克斯。
FWIW我使用以下JavaScript代码生成了否定部分:
var str = '';
var ret = '';
'screens'.split('').forEach(function(c) {
ret += (ret ? '|' : '') + str + '(?:[^' + c + ']|$)';
str += c;
});
'(?:' + ret + ')';https://stackoverflow.com/questions/28733414
复制相似问题