牛骨文教育服务平台(让学习变的简单)
博文笔记

ThinkPHP截取部分文章文字、字符串

创建时间:2016-11-17 投稿人: 浏览次数:842

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为不显示 

在function.php定义msubstr函数

function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true){
    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."...";
    }else{
        return $slice;
    }
}

调用该函数:

{$vo["title"]|msubstr=5,5,"utf-8",false}

本文地址:http://liuyanzhao.com/3562.html

转载请注明

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。