本文實例講述了thinkphp中字元截取函數msubstr()用法。分享給大家參考,如下:
ThinkPHP有一個內建字元截取函數msubstr()如下:
msubstr($str, $start=0, $length, $charset="utf-8", $suffix =true)
$str:要截取的字串
$start=0:開始位置,預設從0開始
$length:截取長度
$charset="utf-8":字元編碼,預設UTF-8
$suffix=true:是否在截取後的字元後面顯示省略號,預設true顯示,false為不顯示
呼叫如下
{$vo.title|msubstr=5,5,'utf-8',false}
解釋:截取字串$vo.title,從第5個字元開始,截取5個字元,編碼為UTF-8,不顯示省略號
最近在用thinkphp寫程式的時候遇到 Call to undefined function msubstr() 這樣一個報錯,
原因分析:
在前台模板中用到了msubstr|msubstr ###,5,5,'utf-8',false 這個函數來截取字元數量;
問題出現:
開始在本地寫的時候是windows作業系統沒報錯,後來把專案上傳到Linux伺服器的時候訪問前台報Call to undefined function msubstr()這個錯;
問題排除:
開始在think官方看到有小伙伴們貼出來了要在公共函數庫下定義這個函數;函數如下:
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=false){ if(function_exists("mb_substr")){ if($suffix) return mb_substr($str, $start, $length, $charset)."..."; else return mb_substr($str, $start, $length, $charset); }elseif(function_exists('iconv_substr')) { if($suffix) return iconv_substr($str,$start,$length,$charset)."..."; else 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; }
定義完之後在本地可以使用;也看到有小夥伴們說要把這個函數放到Thinkphp核心函數文件下可以解決Call to undefined function msubstr()報錯問題,放在自己的專案Common目錄下的common. php下說無效,但是不想改動Think的核心文件方便以後升級;
解決方案:
還是Linx下的文件大小寫問題,經我仔細查看發現,由於項目不會自動生成common.php要手動建,原來我在本地專案下的Common下的common.php的C寫成了大寫,然後查看官方的核心Common下的common.php的C是小寫。最後把他改成小寫問題解決;
記錄一下,避免以後再犯這種低級錯誤!
希望本文所述對大家以thinkPHP框架為基礎的PHP程式設計有所幫助。
更多ThinkPHP 模板substr的截取字串函數詳解相關文章請關注PHP中文網!