截断功能不起作用

时间:2013-01-10 17:58:45

标签: php mysql function truncate

我从mysql数据库中提取一些数据并用它构建一个表。我有一个截断函数来砍掉很长的字符串。

这是截断函数:

    function myTruncate($string, $limit, $break=".", $pad="...")
    {
      // return with no change if string is shorter than $limit
      if(strlen($string) <= $limit) return $string;

      // is $break present between $limit and the end of the string?
      if(false !== ($breakpoint = strpos($string, $break, $limit))) {
        if($breakpoint < strlen($string) - 1) {
          $string = substr($string, 0, $breakpoint) . $pad;
        }
      }
      return $string;
    }

这是调用函数的表构建位:

    while($row = mysql_fetch_assoc($liveItemQuery)){
       //get donation type
       $content .= "<tr><td>" . $i . "</td><td>" . $row['timestamp'] . "</td><td>" . myTruncate($row['description'], 25) . "</td><td>" . $row['po_number'] . "</td><td>" . number_format($row['amount'], 2) . "</td><td><a href=\"?view=expenses&itemid=" . $row['id'] . "\">Edit</a></td></tr>";
       $i++;
   }

话虽如此,但是没有在描述字段上执行截断。值得注意的是,description在数据库中存储为数据类型text。此外,myTruncate($row['description'], 25)的var转储报告string(1995),即文本的全长。

那是怎么回事?

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

“无论如何都会截断”。更容易。

function myTruncate($s, $len){
    return substr($s, 0, $len) . (strlen($s)>$len? '...':'');
}