У меня есть строка как www.host.com
и мне нужно убрать начало с него (в данном случае www.
) сделать это просто host.com
, Существует множество этих начал (например: m.
, wap.
и так далее). Как это сделать быстро и эффективно?
В настоящее время я использую этот код, но я думаю, что должен быть лучший / быстрее / чище способ:
<?php
function _without_start( $val, $start )
{
if( _starts( $val, $start ) )
{
$len = mb_strlen( $start );
$val = mb_substr( $val, $len );
}
return $val;
}
function _starts( $str, $needle )
{
return ( mb_substr( $str, 0, mb_strlen($needle) ) === $needle );
}
/********************************************/
$host = 'www.host.com';
$remove_from_beginning = array( 'www.', 'wap.', 'admin.' );
foreach( $remove_from_beginning as $start )
{
$host = _without_start( $host, $start );
}
var_dump( $host );
Вам не нужно foreach для удаления чего-то из строки, это будет лучше,
$url = preg_replace("/^(www|wap)\./si","","www.wap.com");
echo $url;
С explode
а также in_array
:
function _without_start($host, $prefixes) {
list($prefix, $remainder) = explode('.', $host, 2);
return in_array($prefix, $prefixes) ? $remainder : $host;
}
$prefixes = ['www', 'wap', 'admin'];
$host = 'www.host.com';
echo _without_start($host, $prefixes);
Так как вы добавили Regex тег вы можете сделать список, используя внесение изменений в регулярном выражении и проверить его на строку и заменить на empty
строка.
Regex: ^(www|admin|wap)\.
Если вы готовы к regex
решение на основе (как один из тегов упоминает regex
), Ну вот
$remove_from_beginning = array( 'www.', 'wap.', 'admin.' );
$final = "";
foreach( $remove_from_beginning as $start )
{
$final = $final . "" . substr_replace($start, '', -1) . "" . "\.|";
}
$final = substr_replace($final, '', -1);
echo preg_replace("/" . "" . "(?:" . "" . $final . "" . ")" . "" . "(.*)" . "" . "/", "$1", "www.exaple.com");