快速业务通道

PHP字符串截取

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-23

 

  /**

  * 字符截取 支持UTF8/GBK

  * @param $string

  * @param $length

  * @param $dot

  */

  function str_cut($string, $length, $dot = '...') {

  $strlen = strlen($string);

  if($strlen <= $length) return $string;

  $string = str_replace(array(' ',' ', '&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), array('∵',' ', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), $string);

  $strcut = '';

  if(strtolower(CHARSET) == 'utf-8') {

  $length = intval($length-strlen($dot)-$length/3);

  $n = $tn = $noc = 0;

  while($n < strlen($string)) {

  $t = ord($string[$n]);

  if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {

  $tn = 1; $n++; $noc++;

  } elseif(194 <= $t && $t <= 223) {

  $tn = 2; $n += 2; $noc += 2;

  } elseif(224 <= $t && $t <= 239) {

  $tn = 3; $n += 3; $noc += 2;

  } elseif(240 <= $t && $t <= 247) {

  $tn = 4; $n += 4; $noc += 2;

  } elseif(248 <= $t && $t <= 251) {

  $tn = 5; $n += 5; $noc += 2;

  } elseif($t == 252 || $t == 253) {

  $tn = 6; $n += 6; $noc += 2;

  } else {

  $n++;

  }

  if($noc >= $length) {

  break;

  }

  }

  if($noc > $length) {

  $n -= $tn;

  }

  $strcut = substr($string, 0, $n);

  $strcut = str_replace(array('∵', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), array(' ', '&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), $strcut);

  } else {

  $dotlen = strlen($dot);

  $maxi = $length - $dotlen - 1;

  $current_str = '';

  $search_arr = array('&',' ', '"', "'", '“', '”', '—', '<', '>', '·', '…','∵');

  $replace_arr = array('&',' ', '"', ''', '“', '”', '—', '<', '>', '·', '…',' ');

  $search_flip = array_flip($search_arr);

  for ($i = 0; $i < $maxi; $i++) {

  $current_str = ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];

  if (in_array($current_str, $search_arr)) {

  $key = $search_flip[$current_str];

  $current_str = str_replace($search_arr[$key], $replace_arr[$key], $current_str);

  }

  $strcut .= $current_str;

  }

  }

  return $strcut.$dot;

  }

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号