PHP 汉字截取函数,支持UTF-8、GB2312

前端之家收集整理的这篇文章主要介绍了PHP 汉字截取函数,支持UTF-8、GB2312前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编来看看吧。
经测试代码如下:

/**
 * Utf-8、gb2312都支持的汉字截取函数PHP实现UTF-8、GB2312都支持的汉字截取函数
 * cut_str(字符串,截取长度,开始长度,编码);
 * 编码默认为 utf-8
 * 开始长度默认为 0
 * @param 
 * @author 编程之家 jb51.cc jb51.cc
 **/
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('',$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,2); 
} 
else 
{ 
$tmpstr.= substr($string,1); 
} 
} 
if(ord(substr($string,1))>129) $i++; 
} 
if(strlen($tmpstr)<$strlen ) $tmpstr.= "..."; 
return $tmpstr; 
} 
}
/***   代码来自编程之家 jb51.cc(jb51.cc)   ***/

猜你在找的PHP相关文章