繁体   English   中英

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

[英]Regex Extract matched string from URL (working, better solution?)

所以我基本上我想测试一个url匹配一个域,然后返回(如果它存在)最后一次出现a(划线分隔)组w 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。 这似乎有效,但不确定是否有更好的方法? 也不确定正则表达式是否符合我的条件。 我正在建立一个需要扫描很多很多链接的功能,所以我想找到最好/最快的解决方案

您的正则表达式将匹配以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})

功能很好,但不需要使用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;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM