我正在尝试形成一个正则表达式(javascript/node.js),它将从任何给定的 URL 中提取子域和域部分。这就是我最终的结果:
[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)
现在,我只是考虑使用 http、https 作为协议(protocol)并排除“www”。来自 URL 的子域 + 域部分的部分。我检查了表达式,它几乎可以工作。但是,这里是问题:
成功
'http://mplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
'http://lplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
失败
'http://play.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
'http://tplay.google.co.in/sadfask/asdkfals?dk=10'.match(/[^(?:http:\/\/|www\.|https:\/\/)]([^\/]+)/i)
我只使用结果数组中的第一个元素。我无法理解为什么要“玩”。 &“播放”。不起作用。有人可以在这方面帮助我吗?
“/p”和“/t”对正则表达式求值器有什么意义吗?
有没有其他方法可以使用正则表达式从任何给定的 URL 中提取子域和域?
编辑 -
例子:
https://play.google.com/store/apps/details?id=com.skgames.trafficracer => play.google.com
https://mail.google.com/mail/u/0/#inbox => mail.google.com
最佳答案
关于javascript - 正则表达式 - 提取子域和域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25703360/