>백엔드 개발 >PHP 튜토리얼 >php中文字串截取无乱码的方法_PHP教程

php中文字串截取无乱码的方法_PHP教程

WBOY
WBOY원래의
2016-07-13 10:48:541086검색

在网上找到了很多关于php截取中文方法,其中最多的还是讲到使用mb_substr函数来截取了,这个函数需要php.ini中一个拓展支持,但我没权限修改只有另想办法。

substr截取

substr() 函数返回字符串的一部分。

 

 代码如下 复制代码
 $rest = substr("我是中国人", -1);    // returns "乱码"
 echo $rest.'
';
 $rest = substr("abcdef", -2);    // returns "ef"
 echo $rest.'
';
 $rest = substr("abcdef", -3, 1); // returns "d"
 echo $rest.'
';
?>

接着百度goole说可以mb_substr截取

 代码如下 复制代码


echo mb_substr('我们都是好孩子hehe',0,9);
?>

运行机制提示

Fatal error: Call to undefined function mb_substr()...

后来有朋友告诉我是一般的服务器都没打开php_mbstring.dll,需要在php.ini中把php_mbstring.dll打开,找到idc商不开,只有另想办法

 代码如下 复制代码

function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)
    {
        if(function_exists("mb_substr"))
            return mb_substr($str, $start, $length, $charset);
        elseif(function_exists('iconv_substr')) {
            return iconv_substr($str,$start,$length,$charset);
        }
        $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($suffix) return $slice."…";
        return $slice;
    }

这个正好解决了所有问题了,看上是按字符编码来进行截取了

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/632743.htmlTechArticle在网上找到了很多关于php截取中文方法,其中最多的还是讲到使用mb_substr函数来截取了,这个函数需要php.ini中一个拓展支持,但我没权限修...
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.