php 无乱码字符截取中文的解决办法
内容摘要
这篇文章主要为大家详细介绍了php 无乱码字符截取中文的简单示例,具有一定的参考价值,可以用来参考一下。
对php按字符截取中文并保证无乱码的方法对此感兴趣的朋友,看看idc笔
对php按字符截取中文并保证无乱码的方法对此感兴趣的朋友,看看idc笔
文章正文
这篇文章主要为大家详细介绍了php 无乱码字符截取中文的简单示例,具有一定的参考价值,可以用来参考一下。
对php按字符截取中文并保证无乱码的方法对此感兴趣的朋友,看看idc笔记做的技术笔记!
/**
* php按字符截取中文并保证无乱码的方法
*
* @param
* @arrange 五一二笔记网: 512pic.com
**/
//$str 待截取的字符串
//$len 截取的字符个数
//$chars 已经截取的字符数
//$res 保存的字符串
//$chars 保存已经截取的字符串个数
//$offset 截取的偏移量
//$length 字符串的字节数
//若$len>$str的字符个数,造成无谓的while循环,($offset<$length限定)
function utf8sub($str,$len){
if($len<=0){
return ;
}
$res="";
$offset=0;
$chars=0;
$length=strlen($str);
while($chars<$len && $offset<$length){
$hign=decbin(ord(substr($str,$offset,1)));
if(strlen($hign)<8){
$count=1;
}elseif(substr($hign,0,3)=="110"){
$count=2;
}elseif(substr($hign,0,4)=="1110"){
$count=3;
}elseif(substr($hign,0,5)=="11110"){
$count=4;
}elseif(substr($hign,0,6)=="111110"){
$count=5;
}elseif(substr($hign,0,7)=="1111110"){
$count=6;
}
$res.=substr($str,$offset,$count);
$offset+=$count;
$chars+=1;
}
return $res;
}
function utf8sub1($str,$len){
$chars=0;
$res="";
$offset=0;
$length=strlen($str);
while($chars<$len && $offset<$length){
$hign=decbin(ord(substr($str,$offset,1)));
if(strlen($hign)<8){
$count=1;
}elseif($hign & "11100000"=="11000000"){
$count=2;
}elseif($hign & "11110000"=="11100000"){
$count=3;
}elseif($hign & "11111000"=="11110000"){
$count=4;
}elseif($hign & "11111100"=="11111000"){
$count=5;
}elseif($hign & "11111110"=="11111100"){
$count=6;
}
$res.=substr($str,$offset,$count);
$chars++;
$offset+=$count;
}
return $res;
}
$a="中华ah人民hdj";
echo utf8sub($a,5);
/*** 来自php教程(www.idcnote.com) ***/
注:关于php 无乱码字符截取中文的简单示例的内容就先介绍到这里,更多相关文章的可以留意
代码注释