0

我想知道是否有人知道从另一个链接中提取链接的最佳方法是什么,这是一个示例:

如果我有以下格式的链接:

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

我想知道我是否可以使用 PHP 使用什么正则表达式来实现这一点,正则表达式也是要走的路吗?

4

3 回答 3

2

有一个用于解析 URL 的 PHP 函数:parse_url

$url = 'http://it.answers.yahoo.com/question/index?qid=20080520042405AApM2Rv';
$p = parse_url($url);
echo $p["scheme"] . "// . "$p["host"];
于 2013-03-21T08:30:09.733 回答
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];

Codeviper 演示。

于 2013-03-21T08:39:11.510 回答
0

您只想拥有页面的域,在 PHP 中有一个名为parse_url的函数可以提供帮助

于 2013-03-21T08:31:11.047 回答