PHP支持多种编码截取中文字符串的函数
PHP #截取中文字符串 #函数2012-10-29 15:08
通过使用多种方法来实现中文字符串的完美截取,在未安装mbstring 和 iconv扩展情况下支持UTF-8、GBK、GB2312、BIG5编码,安装上述扩展后支持的编码更多,详细情况参考函数说明。
共有三种方法
1、mb_substr() 需要 mbstring 扩展2、iconv_substr() 需要 iconv扩展
3、正则匹配,默认支持
三种方法优先顺序从上至下,上一种方法不可用则自动使用下一种方法。
<?php /** * 字符串截取,支持中文和其他编码 * * @author http://yige.org/php/ * @param string $str 需要转换的字符串 * @param string $start 开始位置 * @param string $length 截取长度 * @param string $charset 编码格式 * @param string $suffix 截断字符串后缀 * @return string */ function substr_ext($str, $start=0, $length, $charset="utf-8", $suffix="") { if(function_exists("mb_substr")){ return mb_substr($str, $start, $length, $charset).$suffix; } elseif(function_exists('iconv_substr')){ return iconv_substr($str,$start,$length,$charset).$suffix; } $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 $slice.$suffix; }
相关文章
- PHP用三个类概况五种设计模式 2012/10/29
- php获取文件创建时间/修改时间 2012/10/29
- PHP读写大日志文件 2012/10/29
- PHP制作中文圆形印章示例 2012/10/29
- PHP实现GBK/UTF-8编码自动转换的函数 2012/10/29
- PHP无限级分类数据格式化成树 2012/10/29
- PHP设计模式之外观模式 2012/10/29
- php网页密码登录代码 2012/10/29
- PHP用fsocket模拟GET和POST请求 2012/10/29
- paip.PHP实现跨平台跨语言加解密的方法 2012/10/29