注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

面包会有的

php asp 高端网站开发 微信网站开发 视频会议软硬件

 
 
 

日志

 
 

PHP截取字符串---汉字算2个字符并且防止截出乱码  

2012-11-03 03:57:46|  分类: 帝国cms |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

以前我处理截取字符串为了防止截出乱码都是把汉字和英文当一个字符处理。

但这样处理非常不利于上下行文字对齐。

最后想了如下办法。。虽然不高效,但算是解决问题了……

 

 

/**
 * 截取字符串(汉字算2个字符并且防止截出乱码--目前只支持从第0位开始截取)
 *
 * @param String $string 要截取的字符串
 * @param Int $start 从第几位开始截
 * @param Int $length 要截取的长度
 * @param String $fixStr 当字符长度大于$end时,给字符追加的字符
 */
function s_substr($string,$start,$length = null,$fixStr = '')
{
    if (!$string || empty($string)) {
        return $string;
    }

 

    $maxLen = ($length) ? $length - $start : $start;
    //如果字符总长度大于要截取的长度,那么少截取“$fixStr长度”个字符,追加$fixStr
    if (strlen($string) > $maxLen) {
        $maxLen = $maxLen - strlen($fixStr);
    }
    for ($i = $start; $i < $maxLen; $i++)
    {
        if (ord(substr($string, $i, 1)) > 0xa0) {
            if ($i + 1 == $maxLen) {
                //如果截取的最后一字是汉字,那么舍弃该汉字,结束截取
                break;
            } else {
                //如果是中文,截取2个字符
                $strRes .= substr($string, $i, 2);
                $i++;
            }
        } else {
            //如果是英文,截取1个字符
            $strRes .= substr($string, $i, 1);
        }
    }
    if (strlen($string) > $maxLen) {
        $strRes .= $fixStr;
    }
   
    return $strRes;
}

 


$str = '加菲的博客:http://wmnmtm.blog.163.com';

echo s_substr($str,0,15,'..');


加菲推荐阅读:
  评论这张
 
阅读(1044)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017