字符串截取,支持中文和其他编码
2017-02-07 10:48
302 查看
很多时候,我们会碰到一种情况:要输出很长一串评论或者标题,但是长度不允许,在这种时候,我们就需要隐藏一部分不显示。。。这个时候,我们可能会碰到另一个问题:中文截取,一个中文可能占两个字节或者三个字节,搞不好就会截出来一段乱码,这个时候怎么办呢?可以直接用mb_substr截取(支持中文,详细请看官方文档),也可以用下面这种方法。代码片段:
/** * 字符串截取,支持中文和其他编码 * @static * @access public * @param string $str 需要转换的字符串 * @param string $start 开始位置 * @param string $length 截取长度 * @param string $charset 编码格式 * @return string */ function msubstr($str, $start=0, $length, $charset="utf-8") { if(function_exists("mb_substr")) $slice = mb_substr($str, $start, $length, $charset); elseif(function_exists('iconv_substr')) { $slice = iconv_substr($str,$start,$length,$charset); }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)); } if(mb_strlen($str, 'utf8') > $length){ return $slice.'...'; }else{ return $slice; } }
相关文章推荐
- 【转】字符串截取,支持中文和其他编码
- 支持中文和其他编码的php截取字符串函数分享(截取中文字符串)
- PHP小程序--字符串截取,支持中文和其他编码
- php字符串截取,支持中文和其他编码
- php 字符串截取.支持中文和其他编码,,检查字符串是否是UTF8编码
- 支持中文和其他编码的php截取字符串函数分享(截取中文字符串)
- php字符串截取,支持中文和其他编码
- 支持多种编码的中文字符串截取函数
- php截取中文字符串,支持多种编码方式
- PHP----字符串(支持中文和其它编码)截取,后加自定义标识符
- 支持多种编码的中文字符串截取函数! AND 函数实现解压功能
- php中支持多种编码的中文字符串截取函数!
- php中支持多种编码的中文字符串截取函数!
- 支持中文的PHP字符串截取函数 (附各语言的字符集编码范围)
- 对于比较好的支持中文截取字符串的方法。mb_substr
- smarty截取中文字符乱码问题的解决支持utf-8编码
- 收藏几个支持中文的PHP字符串截取函数
- JS~字符串长度判断,超出进行自动截取(支持中文)
- substr 扩展版:支持中文字符串截取
- Java按字节截取字符串(支持中文)!