您的位置:首页 > 编程语言 > PHP开发

PHP中字符串超长的中英文混合截取

2016-08-04 10:12 513 查看
在网站的建设中,很多时候都会遇到文章标题超出分区限制的情况,这时候需要我们截取超出的部分,把超出部分做省略处理,这样用户就可以点击链接跳转再查看详情了。PHP自带的函数也可以截取字符串,例如$str|substr=a,b;这样可以截取字符串$str的从第a位开始的b个字符串,但是,很多时候文章标题中含有英文等字符,英文和汉字在存储时所占的空间不一样大,我们就无法按单个存储的字节倍数截取正好的字数,这样很多那时候都会在网站中出现黑块,字显示不完整的情况,然后我们就需要写一个可以中英文混合截取的字符串截取函数。代码如下:
/**
* 字符串截取,支持中文和其他编码
* @static
* @access public
* @param string $str 需要转换的字符串
* @param string $start 开始位置
* @param string $length 截取长度
* @param string $charset 编码格式
* @param string $suffix 截断显示字符
* @return string
*/
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true) {
if(function_exists("mb_substr"))
$slice = mb_substr($str, $start, $length, $charset);
elseif(function_exists('iconv_substr')) {
$slice = iconv_substr($str,$start,$length,$charset);
if(false === $slice) {
$slice = '';
}
}else{
$re['utf-8']   = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
$re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
$re['gbk']    = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
$re['big5']   = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/";
preg_match_all($re[$charset], $str, $match);
$slice = join("",array_slice($match[0], $start, $length));
}
return $suffix ? $slice.'...' : $slice;
}
我们只需要把这个函数写到公共函数里就可以直接使用了
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息