支持多种编码的中文字符串截取函数!
/* <BR> * @todo 中文截取,支持gb2312,gbk,utf-8,big5 <BR> * <BR> * @param string $str 要截取的字串 <BR> * @param int $start 截取起始位置 <BR> * @param int $length 截取长度 <BR> * @param string<span>%本文来源gaodai#ma#com搞*代#码9网#</span><strong>搞gaodaima代码</strong> $charset utf-8|gb2312|gbk|big5 编码 <BR> * @param $suffix 是否加尾缀 <BR> */ <br><br>function csubstr($str, $start=0, $length, $charset="utf-8", $suffix=true) <BR>{ <BR> if(function_exists("mb_substr")) <BR> return mb_substr($str, $start, $length, $charset); <BR> $re['utf-8'] = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/"; <BR> $re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/"; <BR> $re['gbk'] = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/"; <BR> $re['big5'] = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/"; <BR> preg_match_all($re[$charset], $str, $match); <BR> $slice = join("",array_slice($match[0], $start, $length)); <BR> if($suffix) return $slice."…"; <BR> return $slice; <BR>} <BR>