PHP 字符串编码截取函数(兼容utf-8和gb2312)
代码如下:
//截取字符串长度。支持utf-8和gb2312编码。若为gb2312,先将其转为utf-8,在utf-8的基础上截取然后再转换回来 function cut_string($str,$from=1,$length=10,$code='utf-8',$rear='...'){ if($code!='utf-8'){//总是将字符串转为utf-8编码 $str=iconv($code,'utf-8',$str); } $str_len=mb_strlen($str,'utf-8');//字符串的长度 if($from>$str_len){//如果截取开始位置大于字符串长度,截取后面$length个 $from=$str_len-$length+1; $from=($from<1?1:$from); } //兼容ucs-4编码 $i=0;//字节计数 $from_i=0;//开始截取的字节位置 $from_len=0;//开始截取的字符位置 $tag=true;//标志$from_len是否已经被赋值 for($temp_len=0;($temp_len-$from_len<$length)||$tag;$temp_len++){ $byte_code=ord(substr($str,$i,1));//一个字节的编码 if($temp_len+1==$from){//记录开始截取的开始字节位置 $from_i=$i;$from_len=$temp_len;$tag=false; } if($byte_code>=0&&$byte_code<128){//字符是占用几个字节,utf-8是变长编码,根据每个字符的第一个字节可判断出该字符占几个字节 $i++; } if($byte_code>191&&$byte_code<224){ $i+=2; } if($byte_code>223&&$byte_code<240){ $i+=3; } if($byte_code>239&&$byte_code<248){ $i+=4; } if($byte_code>248&&$byte_code<252){ $i+=5; } if($byte_code>252&&$byte_code<255){ $i+=6; } } return iconv('utf-8',$code,substr($str,$from_i,$i-$from_i).$rear); }
相关推荐
81214051 2020-04-25
84590091 2020-04-22
82056521 2019-11-03
Jiajinjin 2009-11-04
赵丹icons逐LJ 2012-01-09
清月 2011-11-03
SwingGUI 2012-03-25
paopaocbg 2014-02-13
心中要有一片海 2012-10-22
chinesexj 2012-02-16
Enn的数据库 2011-08-22
87437616 2011-05-09
paopaocbg 2010-10-21
微软FixIt 2014-03-20
Legend 2013-06-30
qiaosym 2010-07-07