マルチバイトセーフであると私は信じて います。どちらにしても、マルチバイトセーフであるため、ラップすることができます。strtr
str_replace
function mb_strtr($str, $from, $to)
{
return str_replace(mb_str_split($from), mb_str_split($to), $str);
}
関数がないmb_str_split
ため、独自の関数を作成する必要があります(mb_substr
andを使用)。または、 PHP UTF-8実装mb_strlen
を使用することもできます(わずかに変更)。
function mb_str_split($str) {
return preg_split('~~u', $str, null, PREG_SPLIT_NO_EMPTY);;
}
ただし、文字列からすべての(ラテン語?)アクセントを削除する関数を探している場合は、次の関数が役立つ場合があります。
function Unaccent($string)
{
return preg_replace('~&([a-z]{1,2})(?:acute|cedil|circ|grave|lig|orn|ring|slash|th|tilde|uml|caron);~i', '$1', htmlentities($string, ENT_QUOTES, 'UTF-8'));
}
echo Unaccent('ľľščťžýáíŕďňä'); // llsctzyairdna
echo Unaccent('Iñtërnâtiônàlizætiøn'); // Internationalizaetion