我想知道是否有人知道从另一个链接中提取链接的最佳方法是什么,以下是一个例子:
如果我有以下格式的链接:
http://www.youtube.com/watch?v=35HBFeB4jYg OR
http://it.answers.yahoo.com/question/index?qid=20080520042405AApM2Rv OR
https://www.google.it/search?q=rap+tedesco&aq=f&oq=rap+tedesco&aqs=chrome.0.57j62l2.2287&sourceid=chrome&ie=UTF-8#hl=en&sclient=psy-ab&q=migliori+programatori&oq=migliori+programatori&gs_l=serp.3..0i19j0i13i30i19l3.9986.13880.0.14127.14.10.0.4.4.0.165.931.6j4.10.0...0.0...1c.1.7.psy-ab.tPmiWRyUVXA&pbx=1&bav=on.2,or.r_cp.r_qf.&fp=ffc0e9337f73a744&biw=1280&bih=699
我如何才能仅提取网页:
http://www.youtube.com
http://it.answers.yahoo.com
https://www.google.it
我想知道是否以及我可以使用哪些正则表达式来实现这一点,这也是正则表达式的方法吗?
答案 0 :(得分:2)
有一个用于解析URL的PHP函数:parse_url
$url = 'http://it.answers.yahoo.com/question/index?qid=20080520042405AApM2Rv';
$p = parse_url($url);
echo $p["scheme"] . "// . "$p["host"];
答案 1 :(得分:1)
使用函数parse_url。
$link = "https://www.google.it/search?q=rap+tedesco";
$parseUrl = parse_url($link);
$siteName = $parseUrl['scheme']."://". $parseUrl['host'];
使用正则表达式。
preg_match('@http(s?)://([\w]+\.){1}([\w]+\.?)+@',$link,$matches);
echo $matches[0];
答案 2 :(得分:0)
你只想拥有页面的域名,在PHP中存在一个名为parse_url的函数可以提供帮助