正则表达式从URL中提取匹配的字符串(工作,更好的解决方案?)

时间:2013-07-13 12:54:36

标签: javascript regex performance

所以我基本上我想测试一个url匹配一个域,然后返回(如果它存在)最后一次出现a(短划线)组4-5个字符和3-5个数字。

function testLink (link) {
  var reg = /test.com.*-([A-Z]{4,5}[0-9]{3,5})/i;
  return try { link.match(reg)[1] } catch(e) { false }
}

testLink('http://www.test.com/something-test-C34-CAA0004-CJFE348');
==> CJFE348

匹配返回带有完整测试字符串的数组,然后返回我的模式。如果失败,则try catch将被命中并返回false。这似乎有效,但不确定是否有更好的方法?也不确定正则表达式是否符合我的条件。我正在建立一个需要扫描很多很多链接的功能,所以我想找到最好/最快的解决方案

2 个答案:

答案 0 :(得分:2)

您的正则表达式将匹配以test ...结尾的域名

www.softwaretest.com/.....
www.valvetest.com/....

此外,您尚未使用.[.]转义\.,因此它也会匹配

www.test1com.com/...
www.testXcom.com/....

你的正则表达式应该是

https?://(www[.])?test[.]com.*-([A-Z]{4,5}[0-9]{3,5})

答案 1 :(得分:1)

该功能很好,但不需要使用try-catch

function testLink (link) {
  var your_match = link.match(/test.com.*-([A-Z]{4,5}[0-9]{3,5})/i);
  // Not sure why do you want to return "false" rather than "null"
  return your_match ? your_match[1] : null;
}