gpt4 book ai didi

javascript - 正则表达式 - 提取子域和域

转载 作者:行者123 更新时间:2023-12-03 13:03:28 24 4
gpt4 key购买 nike

我正在尝试形成一个正则表达式(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

最佳答案

您的正则表达式似乎不正确。试试这个正则表达式:

/^(?:https?:\/\/)?(?:[^@\n]+@)?(?:www\.)?([^:\/\n?]+)/img

RegEx Demo

关于javascript - 正则表达式 - 提取子域和域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25703360/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com