是否有string函数,search是一个正则表达式,它会在最后开始搜索?
如果没有,从最后开始搜索正则表达式索引的最快和/或最干净的方法是什么?
正则表达式的例子:
/<\/?([a-z][a-z0-9]*)\b[^>]*>?/gi
答案 0 :(得分:2)
也许这可能更有用也更容易:
str.lastIndexOf(str.match(<your_regex_here>).pop());
答案 1 :(得分:1)
您可以创建一个反向函数,如:
function reverse (s) {
var o = '';
for (var i = s.length - 1; i >= 0; i--)
o += s[i];
return o;
}
然后使用
var yourString = reverse("Your string goes here");
var regex = new Regex(your_expression);
var result = yourString.match(regex);
另一个想法:如果你想按相反的顺序搜索,那么
function reverseWord(s) {
var o = '';
var split = s.split(' ');
for (var i = split.length - 1; i >= 0; i--)
o += split[i] + ' ';
return o;
}
var yourString = reverseWord("Your string goes here");
var regex = new Regex(your_expression);
var result = yourString.match(regex);
答案 2 :(得分:1)
Andreas从评论中得出了这个:
https://stackoverflow.com/a/274094/402037
String.prototype.regexLastIndexOf = function(regex, startpos) {
regex = (regex.global) ? regex : new RegExp(regex.source, "g" + (regex.ignoreCase ? "i" : "") + (regex.multiLine ? "m" : ""));
if(typeof (startpos) == "undefined") {
startpos = this.length;
} else if(startpos < 0) {
startpos = 0;
}
var stringToWorkWith = this.substring(0, startpos + 1);
var lastIndexOf = -1;
var nextStop = 0;
while((result = regex.exec(stringToWorkWith)) != null) {
lastIndexOf = result.index;
regex.lastIndex = ++nextStop;
}
return lastIndexOf;
}
这提供了我需要的功能,我测试了我的正则表达式,并且它是成功的。所以我会用这个
答案 3 :(得分:1)
也许这样的事情适合你?
的Javascript
function lastIndexOfRx(string, regex) {
var match = string.match(regex);
return match ? string.lastIndexOf(match.slice(-1)) : -1;
}
var rx = /<\/?([a-z][a-z0-9]*)\b[^>]*>?/gi;
console.log(lastIndexOfRx("", rx));
console.log(lastIndexOfRx("<i>it</i><b>bo</b>", rx));
只是为了兴趣,这个功能与您选择的功能相对应。 jsperf
这要求您正确格式化正则表达式以准确匹配所需的模式和全局(如问题中给出的),例如/.*(<\/?([a-z][a-z0-9]*)\b[^>]*>?)/i
将无法使用此函数。但你得到的是一个干净而快速的功能。
答案 4 :(得分:0)
这取决于您想要搜索的内容。您可以使用string.lastIndexOf
或在正则表达式中使用$
(字符串的结尾)。
<强>更新强> 试试正则表达式
/<\/?([a-z][a-z0-9]*)\b[^>]*>?[\w\W]*$/gi
答案 5 :(得分:0)
假设您正在寻找字符串'token',那么您需要“令牌”的位置,该位置没有其他“令牌”,直到字符串结尾。
所以你应该把你的正则表达式写成:
$token = 'token';
$re = "/(?:$token)[^(?:$token)]*$/";
这将找到你的'令牌',在字符串结束之前不能再找到'令牌'。 “(?:”分组只是使组不存储,略微加快了性能并节省了内存。
答案 6 :(得分:0)
var m = text.match(/.*(<\/?([a-z][a-z0-9]*)\b[^>]*>?)/i);
if (m) {
textFound = m[1];
position = text.lastIndexOf(textFound);
}
使用。*跳过尽可能多的文本,捕获找到的文本并用lastIndexOf搜索
编辑:
好吧,如果找到文本,则无需使用lastIndexOf进行搜索。 m [0]包含完全重合(包括所有初始填充),并且m [1]包含搜索文本。所以找到文本的位置是m [0] .length - m [1] .length
var m = text.match(/.*(<\/?([a-z][a-z0-9]*)\b[^>]*>?)/i);
if (m) {
textFound = m[1];
position = m[0].length - m[1].length;
}