说是最精确截取长度,其实我也不敢确定是否是最精确的,具体有多精确看下面的效果就知道了: 先上测试用的字符串:
rush:PHP;">
PHP
header("Content-Type:text/html;charset=utf-8");
echo cn_substr_utf8('我是一个,和哈,哦也,,国家!',12);
echo '
',cn_substr_utf8('ai\'2145m a ch3我[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【我,是一,个,和哈,哦也,,国家!',cn_substr_utf8('我是一,个,和哈,哦也,,国家!',cn_substr_utf8('我是,一,个,和哈,哦也,,国家!',cn_substr_utf8('我,是,cn_substr_utf8('我是asd一,个,和哈,哦也,,国家!',cn_substr_utf8('【我i\'m[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【i\'m a ch我[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【i\'2145m a ch3我[是一,个,和哈,哦也,,国家!',12);
',cn_substr_utf8('ai\'2145m a ch3我[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【我,是一,个,和哈,哦也,,国家!',cn_substr_utf8('我是一,个,和哈,哦也,,国家!',cn_substr_utf8('我是,一,个,和哈,哦也,,国家!',cn_substr_utf8('我,是,cn_substr_utf8('我是asd一,个,和哈,哦也,,国家!',cn_substr_utf8('【我i\'m[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【i\'m a ch我[是一,个,和哈,哦也,,国家!',cn_substr_utf8('【i\'2145m a ch3我[是一,个,和哈,哦也,,国家!',12);
rush:PHP;">
//utf-8中文截取,单字节截取模式
function cn_substr_utf8($str,$length,$append='...',$start=0){
if(strlen($str)<$start+1){
return '';
}
preg_match_all("/./su",$str,$ar);
$str2='';
$tstr='';
//www.PHPernote.com
for($i=0;isset($ar[0][$i]);$i++){
if(strlen($tstr)<$start){
$tstr.=$ar[0][$i];
}else{
if(strlen($str2)<$length + strlen($ar[0][$i])){
$str2.=$ar[0][$i];
}else{
break;
}
}
}
return $str==$str2?$str2:$str2.$append;
}
如果大家认为还不够准确大家可以在此基础上进行改进,或者是创新,希望这篇关于PHP截取字符串长度函数的文章对大家的学习有所帮助。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。