Conversion des caractères accentués en caractères de base en PHP
Le langage PHP fournit des fonctionnalités permettant de remplacer les caractères accentués par leurs homologues de base.
Utilisation de la classe Normalizer
La classe Normalizer est conçue pour la normalisation des caractères, y compris les accents et autres signes diacritiques. Pour supprimer les accents à l'aide de cette classe :
<code class="php">use Normalizer; $string = Normalizer::normalize($string, Normalizer::FORM_D);</code>
Remplacement personnalisé des caractères accentués
Si vous ne souhaitez pas utiliser la classe Normalizer ou si vous devez personnaliser le remplacement des accents, vous pouvez utiliser la fonction suivante :
Code :
<code class="php">function unaccent($string) { return preg_replace('~&([a-z]{1,2})(acute|cedil|circ|grave|lig|orn|ring|slash|th|tilde|uml);~i', '', htmlentities($string, ENT_QUOTES, 'UTF-8')); }</code>
Exemple d'utilisation :
Pour remplacer "ã" avec "a" et "é" avec "e":
<code class="php">$string = "ãé"; $unaccentedString = unaccent($string);</code>
Comment ça marche :
Cette fonction convertit les caractères accentués en leurs représentations d'entité HTML en utilisant htmlentités(). L'expression régulière remplace ensuite l'entité HTML par le caractère de base.
Cette méthode est compatible avec les accents les plus courants, mais elle n'est pas exhaustive et peut ne pas couvrir tous les cas possibles.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!