PHP mb_ereg_replace ne pas remplacer alors que les travaux de preg_replace comme prévu
Question
Je suis en train de remplacer dans une chaîne tous les caractères non-mot avec chaîne vide attendent pour des espaces et de la mettre en place tous les espaces multiples comme un seul espace.
code suivant le fait.
$cleanedString = preg_replace('/[^\w]/', ' ', $name);
$cleanedString = preg_replace('/\s+/', ' ', $cleanedString);
Mais quand je suis en train d'utiliser rien de mb_ereg_replace arrive.
$cleanedString = mb_ereg_replace('/[^\w]/', ' ', $name);
$cleanedString = mb_ereg_replace('/\s+/', ' ', $cleanedString);
$ cleanedString est la même que de si $ nom dans le cas ci-dessus. Qu'est-ce que je fais mal?
La solution
mb_ereg_replace
n'utilise pas de séparateurs. Vous pouvez ou ne peut pas également spécifier l'encodage avant.
mb_regex_encoding("UTF-8");
//regex could also be \W
$cleanedString = mb_ereg_replace('[^\w]', ' ', $name);
$cleanedString = mb_ereg_replace('\s+', ' ', $cleanedString);
Autres conseils
function create_slug_html($string, $ext='.html'){
$replace = '-';
$string=strtolower($string);
$string=trim($string);
mb_regex_encoding("UTF-8");
//regex could also be \W
$string= mb_ereg_replace('[^\w]', ' ', $string);
$string= mb_ereg_replace('\s+', ' ', $string);
//remove query string
if(preg_match("#^http(s)?://[a-z0-9-_.]+\.[a-z]{2,4}#i",$string)){
$parsed_url = parse_url($string);
$string = $parsed_url['host'].' '.$parsed_url['path'];
//if want to add scheme eg. http, https than uncomment next line
//$string = $parsed_url['scheme'].' '.$string;
}
//replace / and . with white space
$string = preg_replace("/[\/\.]/", " ", $string);
// $string = preg_replace("/[^a-z0-9_\s-]/", "", $string);
//remove multiple dashes or whitespaces
$string = preg_replace("/[\s-]+/", " ", $string);
//convert whitespaces and underscore to $replace
$string = preg_replace("/[\s_]/", $replace, $string);
//limit the slug size
$string = substr($string, 0, 200);
//slug is generated
return ($ext) ? $string.$ext : $string;
}
S'il vous plaît vérifier est-il correct et le soutien anglais et unicode
L'entrée est pas multi-octets où la fonction mb
échoue.
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow