Dieser Artikel stellt hauptsächlich die Methode zur Realisierung der chinesischen Zeichenfolgenumkehr vor, um verstümmelte Zeichen zu vermeiden. Jetzt kann ich ihn mit Ihnen teilen
Als der Blogger heute online PHP-Interviewfragen ansah, sah er diese Frage, wie man eine Zeichenfolge umkehrt. Damals dachte er, es gäbe eine eingebaute Funktion strrev. Kann diese Funktion implementiert werden? Ich habe es später ausprobiert und festgestellt, dass diese Funktion nur englische Zeichen umkehren kann und bei chinesischen Zeichen zu verstümmelten Zeichen führt. Der Hauptgrund sind immer noch Codierungsprobleme.
In PHP wird utf-8-codiertes Chinesisch als 3 Bytes berechnet und gb2312 wird als 2 Bytes berechnet. Wenn Sie daher einige Funktionen chinesischer Zeichenfolgen realisieren möchten, müssen Sie zunächst das Codierungsproblem lösen.
Heute startet diese Funktion in der Codierungsabteilung. Lassen Sie uns als nächstes über die implementierten Funktionen sprechen. Heute werden wir diese Funktionen verwenden:
1 2 3 4 5 |
is_string()//判断参数是否为字符串,这个大家应该都知道 mb_check_encoding()//用来检查给定的字符串是否属于指定的编码 mb_strlen()//用来获取字符串长度 mb_substr()//用来截取字符串中的字符 krsort()//将数组按键名由大到小排序上述 Nach dem Login kopieren |
Oben werden drei Funktionen verwendet, die mit mb beginnen. Die mit mb beginnenden Funktionen werden zur Verarbeitung von Multibyte-Strings verwendet, hauptsächlich zur Angabe der String-Kodierung.
mb_check_encoding() akzeptiert zwei Parameter. Der erste Parameter sollte eine Zeichenfolge sein, und der zweite Parameter dient zur Eingabe von a Zeichenkodierung und dann feststellen, ob die Zeichenfolge zu dieser Kodierung gehört, und einen Bool-Wert zurückgeben. Wenn der zweite Parameter weggelassen wird, wird standardmäßig die interne Kodierung verwendet, die über mb_internal_encoding() angezeigt werden kann.
mb_strlen() hat zwei Parameter, der erste ist der String-Inhalt und der zweite ist die Codierung des Strings.
mb_substr() hat vier Parameter. Der erste ist der Inhalt der abzufangenden Zeichenfolge, der zweite ist die Startposition des Abfangens und der dritte Die Länge des Abfangens und der vierte ist die Codierung der Zeichenfolge (wählen Sie in diesem Fall utf-8 aus, andere Codierungen liefern nicht das richtige Ergebnis).
Die kurzen Kommentare wurden tatsächlich markiert Sie können alles auf einmal verstehen:
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); /* 得到结果: * 这是我的技术博客,欢迎多多来访! * !访来多多迎欢,客博术技的我是这 */ Nach dem Login kopieren
|
如果文中有任何错误,敬请指出,以便完善。
本文来自:http://5655237.blog.51cto.com/5645237/1258300
相关推荐:
Das obige ist der detaillierte Inhalt vonSo kehren Sie chinesische Zeichenfolgen in PHP um, um verstümmelte Zeichen zu vermeiden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!