> 백엔드 개발 > PHP 튜토리얼 > 문자열 분할 utf-8(중국어, 일본어, 한국어 등 지원, 효율적)

문자열 분할 utf-8(중국어, 일본어, 한국어 등 지원, 효율적)

WBOY
풀어 주다: 2016-07-25 09:08:02
원래의
1352명이 탐색했습니다.
因为mb_substr、mb_strlen太过低效,故而采用了此段代码。

非原创,主要原理是根据UTF-8的编码特点
0xxxxxxx
110xxxxx 10xxxxxx
1110xxxx 10xxxxxx 10xxxxxx
11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
来获取字符边界,从而确定一个字所占字节数,并处理成数组。


方便对字符操作比较频繁的用户,此函数效率比mb_substr高效10倍,我曾经写过一个「N万违禁词替换类」,在开发此类过程中,详细对比过这两者的效率,此函数明显胜出。
  1. function str_split_utf8($str) {
  2. // place each character of the string into and array
  3. $split = 1;
  4. $array = array(); $len = strlen($str);
  5. for ( $i = 0; $i < $len; ){
  6. $value = ord($str[$i]);
  7. if($value > 0x7F){
  8. if($value >= 0xC0 && $value <= 0xDF)
  9. $split = 2;
  10. elseif($value >= 0xE0 && $value <= 0xEF)
  11. $split = 3;
  12. elseif($value >= 0xF0 && $value <= 0xF7)
  13. $split = 4;
  14. elseif($value >= 0xF8 && $value <= 0xFB)
  15. $split = 5;
  16. elseif($value >= 0xFC)
  17. $split = 6;
  18. } else {
  19. $split = 1;
  20. }
  21. $key = '';
  22. for ( $j = 0; $j < $split; $j, $i ) {
  23. $key .= $str[$i];
  24. }
  25. $array[] = $key;
  26. }
  27. return $array;
  28. }
复制代码


원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿