zoukankan      html  css  js  c++  java
  • 字符串截取,支持中文和其他编码

    很多时候,我们会碰到一种情况:要输出很长一串评论或者标题,但是长度不允许,在这种时候,我们就需要隐藏一部分不显示。。。这个时候,我们可能会碰到另一个问题:中文截取,一个中文可能占两个字节或者三个字节,搞不好就会截出来一段乱码,这个时候怎么办呢?可以直接用mb_substr截取(支持中文,详细请看官方文档),也可以用下面这种方法。代码片段:

    /**
     * 字符串截取,支持中文和其他编码
     * @static
     * @access public
     * @param string $str 需要转换的字符串
     * @param string $start 开始位置
     * @param string $length 截取长度
     * @param string $charset 编码格式
     * @return string
     */
    function msubstr($str, $start=0, $length, $charset="utf-8") {
        if(function_exists("mb_substr"))
            $slice = mb_substr($str, $start, $length, $charset);
        elseif(function_exists('iconv_substr')) {
            $slice = iconv_substr($str,$start,$length,$charset);
        }else{
            $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(mb_strlen($str, 'utf8') > $length){
            return $slice.'...';
        }else{
            return $slice;
        }
    }
  • 相关阅读:
    单点登录原理与简单实现
    关系型数据库中的关键字、主关键字和候选关键字
    无向图的顶点连通度
    memcmp()直接比较两个数组的大小
    静态字典树
    动态字典树
    poj 1149
    poj 2112 floyd+Dinic最大流+二分最小值
    POJ 1698 (二分图的多重匹配)
    网络流算法
  • 原文地址:https://www.cnblogs.com/hupan508/p/6373077.html
Copyright © 2011-2022 走看看