PHP 汉字截取函数,支持UTF-8、GB2312
内容摘要
这篇文章主要为大家详细介绍了PHP 汉字截取函数,支持UTF-8、GB2312,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记。经测试代码如下:
/**
对此感兴趣的朋友,看看idc笔记做的技术笔记。经测试代码如下:
/**
文章正文
这篇文章主要为大家详细介绍了PHP 汉字截取函数,支持UTF-8、GB2312,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记。经测试代码如下: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 39 40 41 42 | <code class = "php" > /** * Utf-8、gb2312都支持的汉字截取函数,PHP实现UTF-8、GB2312都支持的汉字截取函数 * cut_str(字符串, 截取长度, 开始长度, 编码); * 编码默认为 utf-8 * 开始长度默认为 0 * @param * @author php教程 www.idcnote.com **/ function cut_str( $string , $sublen , $start = 0, $code = 'UTF-8' ) { if ( $code == 'UTF-8' ) { $pa = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/" ; preg_match_all( $pa , $string , $t_string ); if ( count ( $t_string [0]) - $start > $sublen ) return join( '' , array_slice ( $t_string [0], $start , $sublen )). "..." ; return join( '' , array_slice ( $t_string [0], $start , $sublen )); } else { $start = $start *2; $sublen = $sublen *2; $strlen = strlen ( $string ); $tmpstr = '' ; for ( $i =0; $i < $strlen ; $i ++) { if ( $i >= $start && $i <( $start + $sublen )) { if (ord( substr ( $string , $i , 1))>129) { $tmpstr .= substr ( $string , $i , 2); } else { $tmpstr .= substr ( $string , $i , 1); } } if (ord( substr ( $string , $i , 1))>129) $i ++; } if ( strlen ( $tmpstr )< $strlen ) $tmpstr .= "..." ; return $tmpstr ; } } /*** 代码来自php教程(www.idcnote.com) ***/ </code> |
注:关于PHP 汉字截取函数,支持UTF-8、GB2312的内容就先介绍到这里,更多相关文章的可以留意
代码注释