Cet article présente principalement la méthode d'inversion des chaînes chinoises en PHP pour éviter les caractères tronqués. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer
.
Quand le blogueur regardait les questions d'entretien PHP en ligne aujourd'hui, il a vu cette question, comment inverser une chaîne. À cette époque, il pensait qu'il y avait un élément intégré. function strrev. Cette fonction peut-elle être implémentée ? Je l'ai essayé plus tard et j'ai découvert que cette fonction ne pouvait inverser que les caractères anglais et provoquerait des caractères tronqués dans les caractères chinois. La principale raison reste les problèmes de codage.
En PHP, le chinois codé en utf-8 est calculé sur 3 octets et gb2312 est calculé sur 2 octets. Par conséquent, si vous souhaitez implémenter certaines fonctions des chaînes chinoises, vous devez d’abord résoudre le problème d’encodage.
Aujourd'hui, cette fonction démarre depuis le service de codage. Parlons ensuite des fonctions implémentées. Aujourd'hui, nous utiliserons ces fonctions :
1 2 3 4 5 |
is_string()//判断参数是否为字符串,这个大家应该都知道 mb_check_encoding()//用来检查给定的字符串是否属于指定的编码 mb_strlen()//用来获取字符串长度 mb_substr()//用来截取字符串中的字符 krsort()//将数组按键名由大到小排序上述 Copier après la connexion |
Trois fonctions commençant par mb sont utilisées ci-dessus. Les fonctions commençant par mb sont utilisées pour traiter des chaînes multi-octets, principalement pour spécifier l'encodage de la chaîne.
mb_check_encoding() accepte deux paramètres. Le premier paramètre doit être une chaîne et le deuxième paramètre doit saisir un. Encodage des caractères, puis déterminez si la chaîne appartient à cet encodage et renvoie une valeur booléenne. Si le deuxième paramètre est omis, la valeur par défaut est l'encodage interne, qui peut être visualisé via mb_internal_encoding().
mb_strlen() a deux paramètres, le premier est le contenu de la chaîne et le second est l'encodage de la chaîne.
mb_substr() a quatre paramètres. Le premier est le contenu de la chaîne à intercepter, le second est la position de départ de l'interception et le troisième est. La longueur de l'interception, et le quatrième est l'encodage de la chaîne (dans ce cas, sélectionnez utf-8, les autres encodages n'obtiendront pas le résultat correct).
Ce qui suit est le code complet. Les brefs commentaires ont été marqués. En fait, il suffit de regarder. Vous pouvez tout comprendre d'un coup :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | <?php header("Content-type:text/html;charset=utf-8"); $s="这是我的技术博客,欢迎多多来访!"; function str_rev($str){ //先判断参数是否为字符串,且为UTF8编码 if(!is_string($str)||!mb_check_encoding($str,"utf-8")){ die("输入的不是utf8类型的字符串"); } //用mb_strlen函获取算utf8字符串的长度 $length=mb_strlen($str,"utf-8"); //声明一个数组备用 $arr=array(); //将字符串拆开放入数组 for($i=0;$i<$length;$i++){ $arr[$i]=mb_substr($str,$i,1,"utf-8"); } //将数组按键名大小反转 krsort($arr); //将数组中单个字符元素重新组合成字符串 $str=implode("",$arr); //将翻转后的字符串返回 return $str; } echo $s."<br>"; echo str_rev($s); /* 得到结果: * 这是我的技术博客,欢迎多多来访! * !访来多多迎欢,客博术技的我是这 */ Copier après la connexion
|
如果文中有任何错误,敬请指出,以便完善。
本文来自:http://5655237.blog.51cto.com/5645237/1258300
相关推荐:
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!