php限制从数据库中读取的内容长度

2025-03-31 20:34:24
推荐回答(4个)
回答1:

function MooCutstr($string, $length, $dot = ' ...') {
 global $charset;
 if(strlen($string) <= $length) {
  return $string;
 }
 $string = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $string);
 $strcut = '';
 if(strtolower($charset) == 'utf-8') {
  $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);
 } else {
  for($i = 0; $i < $length; $i++) {
   $strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
  }
 }
 //$strcut = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $strcut);
 return $strcut.$dot;
}

echo MooCutstr('内容长度内容长度内容长度内容长度内容长度内容长度','5','.....');
?>

回答2:

这个很简单啊。 用strlen()获取title 长度。然后判断该长度大于4 就用substr()截取要保留的长度后边拼接字符串".."。就好了

回答3:

sql语句输出的时候格式化
$sql = "SELECT LEFT(字段名,限制的标题长度) AS title FROM 表名";

回答4:

我只能想到通过循环处理一遍得到的数组 如下:
$i=0;
while($title)
{
if(strlen($title[$i][['title'])>4)
{
$=substr($$title[$i][['title'],4)."…";
}
$i++;

}