整理一下收集的PHP字符串截取函數

程序一:PHP截取中文字符串方法
function msubstr($str, $start, $len) {
$tmpstr = “”;
$strlen = $start + $len;
for($i = 0; $i < $strlen; $i++) {
if(ord(substr($str, $i, 1)) > 0xa0) {
$tmpstr .= substr($str, $i, 2);
$i++;
} else
$tmpstr .= substr($str, $i, 1);
}
return $tmpstr;
}


程序二:PHP截取UTF-8字符串,解決半字符問題

/******************************************************************
* PHP截取UTF-8字符串,解決半字符問題。
* 英文、數字(半角)爲1字節(8位),中文(全角)爲3字節
* @return 取出的字符串, 當$len小於等於0時, 會返回整個字符串
* @param $str 源字符串
* $len 左邊的子串的長度
****************************************************************/
function utf_substr($str,$len)
{
for($i=0;$i<$len;$i++)
{
$temp_str=substr($str,0,1);
if(ord($temp_str) > 127)
{
$i++;
if($i<$len)
{
$new_str[]=substr($str,0,3);
$str=substr($str,3);
}
}
else
{
$new_str[]=substr($str,0,1);
$str=substr($str,1);
}
}
return join($new_str);
}
?>

php utf-8 字符串截取

function cutstr($string, $length) {
preg_match_all("/[x01-x7f]|[xc2-xdf][x80-xbf]|xe0[xa0-xbf][x80-xbf]|[xe1-xef][x80-xbf][x80-xbf]|xf0[x90-xbf][x80-xbf][x80-xbf]|[xf1-xf7][x80-xbf][x80-xbf][x80-xbf]/", $string, $info);
for($i=0; $i $wordscut .= $info[0][$i];
$j = ord($info[0][$i]) > 127 ? $j + 2 : $j + 1;
if ($j > $length - 3) {
return $wordscut.” …”;
}
}
return join(”, $info[0]);
}
$string=”242432反對感是456犯得上廣泛大使館地方7890″;
for($i=0;$i {
echo cutstr($string,$i)."
“;
}
?>

截取utf-8字符串函數

爲了支持多語言,數據庫裏的字符串可能保存爲UTF-8編碼,在網站開發中可能需要用php截取字符串的一部分。爲了避免出現亂碼現象,編寫如下的UTF-8字符串截取函數

關於utf-8的原理請看 UTF-8 FAQ

UTF-8編碼的字符可能由1~3個字節組成,具體數目可以由第一個字節判斷出來。(理論上可能更長,但這裏假設不超過3個字節)
第一個字節大於224的,它與它之後的2個字節一起組成一個UTF-8字符
第一個字節大於192小於224的,它與它之後的1個字節組成一個UTF-8字符
否則第一個字節本身就是一個英文字符(包括數字和一小部分標點符號)。

以前爲某網站設計的代碼(也是現在用在首頁的長度截取的函數)

//$sourcestr 是要處理的字符串
//$cutlength 爲截取的長度(即字數)
function cut_str($sourcestr,$cutlength)
{
$returnstr=';
$i=0;
$n=0;
$str_length=strlen($sourcestr);//字符串的字節數
while (($n<$cutlength) and ($i<=$str_length))
{
$temp_str=substr($sourcestr,$i,1);
$ascnum=Ord($temp_str);//得到字符串中第$i位字符的ascii碼
if ($ascnum>=224) //如果ASCII位高與224,
{
$returnstr=$returnstr.substr($sourcestr,$i,3); //根據UTF-8編碼規範,將3個連續的字符計爲單個字符
$i=$i+3; //實際Byte計爲3
$n++; //字串長度計1
}
elseif ($ascnum>=192) //如果ASCII位高與192,
{
$returnstr=$returnstr.substr($sourcestr,$i,2); //根據UTF-8編碼規範,將2個連續的字符計爲單個字符
$i=$i+2; //實際Byte計爲2
$n++; //字串長度計1
}
elseif ($ascnum>=65 && $ascnum<=90) //如果是大寫字母,
{
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //實際的Byte數仍計1個
$n++; //但考慮整體美觀,大寫字母計成一個高位字符
}
else //其他情況下,包括小寫字母和半角標點符號,
{
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //實際的Byte數計1個
$n=$n+0.5; //小寫字母和半角標點等與半個高位字符寬...
}
}
if ($str_length>$cutlength){
$returnstr = $returnstr . "...";//超過長度時在尾處加上省略號
}
return $returnstr;

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章