我正在编写一个脚本,将我内容的所有网址更改为新地点。
var regex = /.*cloudfront.net/
var pDistro = "newDistro.cloudfront.net/"
for(var i=0;i<strings.length;i++){
strings[i] = strings[i].replace(regex,pDistro);
}
我replace
所做的字符串平均每个约有140个字符。他们的网址遵循以下格式:https://[thing to replace].cloudfront.net/[something]/[something]/[something]
但是这个操作非常慢,大约需要4.5秒来处理一个平均大小的数组。
为什么这么慢?我怎样才能让它更快?
如果这个问题更适合代码回放堆栈交换或其他一些网站,请告诉我,我会将其移到那里。
我在数据库中出现的数据似乎是140个字符。在拉取过程中,发生了一些虚拟化,并在字符串上添加了400多个字符,因此难怪正则表达式需要这么长时间。
140字符串循环所花费的时间要少得多,正如其他人所指出的那样。
故事的寓意:&#34;确保您拥有的数据符合您的预期。和#34;如果你的正则表达式花费的时间太长,请使用较小的字符串和更具体的正则表达式(即没有通配符)&#34;
答案 0 :(得分:6)
答案 1 :(得分:4)
对于这样一个简单的替换,正则表达式可能不是最快的搜索和替换。例如,如果您使用.indexOf()
替换搜索,然后使用.slice()
进行替换,则可以将其加速12-50倍(取决于浏览器)。
我不确定你想要模拟的确切替换逻辑,但是这里的非正则表达方法要快得多:
var pos, str, target = "cloudfront.net/";
var pDistro = "https://newDistro.cloudfront.net/"
for(var i = 0; i < urls.length; i++){
str = urls[i];
pos = str.indexOf(target);
if (pos !== -1) {
results[i] = pDistro + str.slice(pos + target.length);
}
}
添加其他人建议的更智能的正则表达式替换,这是一个比较。更智能的正则表达式肯定有助于正则表达式,但它仍然比仅使用.indexOf()
和.slice()
慢,而且差异在Firefox中最明显:
请参阅此处的jsperf:http://jsperf.com/fast-replacer