在網(wǎng)上找到了很多關(guān)于php截取中文方法,其中最多的還是講到使用mb_substr函數(shù)來截取了,這個(gè)函數(shù)需要php.ini中一個(gè)拓展支持,但我沒權(quán)限修改只有另想辦法.
substr截取:substr() 函數(shù)返回字符串的一部分,代碼如下:
- <?php
- $rest = substr("我是中國人", -1); // returns "亂碼"
- echo $rest.'<br />';
- $rest = substr("abcdef", -2); // returns "ef"
- echo $rest.'<br />';
- $rest = substr("abcdef", -3, 1); // returns "d"
- echo $rest.'<br />';
- ?>
接著百度goole說可以mb_substr截取,代碼如下:
- <?php
- echo mb_substr('我們都是好孩子hehe',0,9);
- ?>
- //運(yùn)行機(jī)制提示
- //Fatal error: Call to undefined function mb_substr()...
后來有朋友告訴我是一般的服務(wù)器都沒打開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;
- }
這個(gè)正好解決了所有問題了,看是否按字符編碼來進(jìn)行截取了.
新聞熱點(diǎn)
疑難解答