0

如何在 UTF 8 中剪切字符串。

我从网上搜索了这个功能:

function cutString($str, $lenght = 100, $end = ' …', $charset = 'UTF-8', $token = '~') {
    $str = strip_tags($str);
    if (mb_strlen($str, $charset) >= $lenght) {
        $wrap = wordwrap($str, $lenght, $token);
        $str_cut = mb_substr($wrap, 0, mb_strpos($wrap, $token, 0, $charset), $charset);   
        return $str_cut .= $end;
    } else {
        return $str;
    }
}

但是这个函数的结果不是太好。因为如果我们设置剪切 200 个字母,它将返回大约 110 个,但我需要大约 200 个。

4

2 回答 2

-1

我认为 wordwrap() 函数在这种情况下做错了手动剪切字符串。我使用这样的函数(只需将 'mb_' 和 $charset 添加到字符串函数):

function str_cut_end_by_word($s, $max_len, $trailer = "...")
{
  if (strlen($s) <= $max_len)
    return $s;

  $s = trim($s);
  $s = substr($s, 0, $max_len);

  for ($i = strlen($s) - 1; $i >= 0; $i--)
  {
    if (in_array($s{$i}, array(" ", "\t", "\r", "\n")))
    {
      return rtrim(substr($s, 0, $i)).$trailer;
    }
  }

  return $s;
}
于 2012-12-09T22:28:40.613 回答
-1

我刚刚测试过它,它工作正常。如果你运行它

echo cutString($mystring, 200);

它从我给它的字符串中返回 201 个字符。

于 2012-12-09T22:21:59.257 回答