但是在英文和漢字混合的情況下會(huì)出現(xiàn)如下問題:
如果有這樣一個(gè)字符串
$str="這是一個(gè)字符串";
為了截取該串的前10個(gè)字符,使用
if(strlen($str)>10) $str=substr($str,10)."…";
那么,echo $str的輸出應(yīng)該是"這是一個(gè)字…"
假設(shè)
$str="這是1個(gè)字符串";
這個(gè)串中包含了一個(gè)半角字符,同樣執(zhí)行:
if(strlen($str)>10) $str=substr($str,10);
由于原字符串$str的第10、11個(gè)字符構(gòu)成了漢字“符”;
執(zhí)行串分割后會(huì)將該漢字一分為二,這樣被截取的串就會(huì)發(fā)現(xiàn)亂碼現(xiàn)象。
請(qǐng)問這種問題如何解決?即要使過長字符串實(shí)現(xiàn)分割,又不能讓它發(fā)生亂碼?
代碼如下:
<?php
//村里有很多,這個(gè)是gb2312
function substrs($content,$length='30')
{
if($length && strlen($content)>$length)
{
$num=0;
for($i=0;$i<$length-3;$i++)
{
if(ord($content[$i])>127)
{
$num++;
}
}
$num%2==1 ? $content=substr($content,0,$length-4):$content=substr($content,0,$length-3);
}
return $content;
}
?>
代碼如下:
function cutstr($string, $length, $dot = ' ...') {
$strcut = '';
for($i = 0; $i < $length - strlen($dot) - 1; $i++) {
$strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
}
return $strcut.$dot;
}
代碼如下:
function cutTitle($str, $len, $tail = ""){
$length = strlen($str);
$lentail = strlen($tail);
$result = "";