我正在尝试理解以下正则表达式,它将域名从URL中提取出来
$host = "www.php.net“
// get last two segments of host name
preg_match('/[^.]+\.[^.]+$/', $host, $matches);
echo "domain name is: {$matches[0]}\n";$matches作为php.net怎么样了?
我被这种模式卡住了。^的意思是免费的。意思是任何焦炭。那么是什么呢。卑劣?免费赠送什么焦炭吗?请帮帮忙
发布于 2014-04-18 21:33:31
如果你是新手,这可能会很棘手。
.通常指任何非空格字符.在一个范围([]),然而,它恢复到它的字面意义,即句号(句号,如果你是美国人)。
^通常的意思是“锚定到字符串的开始”。然而,在一个范围内,当它是该范围中的第一个字符时,它会翻转逻辑,所以它表示的不是表示允许的字符的范围,而是表示DISallowed字符。
因此,模式'/[^.]+\.[^.]+$/'说:
$将其锚定到字符串的末尾,因此步骤1-3必须按顺序排列,直到字符串的最后一个字符为止。顺便提一句,对于主机名匹配来说,这并不是一种水密的模式。它不考虑子域或国家特定的领域超过一个时期(例如".co.uk"),指出两点。
发布于 2014-04-18 21:32:15
你误会了。当点(.)在括号内,它意味着一个DOT,而不是任何字符。所以,^。意味着每一个不是点的字符。
发布于 2014-04-18 21:32:06
在字符类([])中,点的意思就是:一个小点.。
因此,[^.]是指除点/句点以外的任何字符。
https://stackoverflow.com/questions/23162683
复制相似问题