PHP中字符串超长的中英文混合截取
在网站的建设中,很多时候都会遇到文章标题超出分区限制的情况,这时候需要我们截取超出的部分,把超出部分做省略处理,这样用户就可以点击链接跳转再查看详情了。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; }我们只需要把这个函数写到公共函数里就可以直接使用了
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: js中获取并遍历php数组
- 下一篇: 大文件上传,修改php.ini的配置之后仍不生效解决方法