[精讚] [會員登入]
1704

[PHP] UTF8中取出字串中特定的字數

要將字串,例如資料庫取出的TEXT,取出特定的字數

分享此文連結 //n.sfs.tw/11609

分享連結 [PHP] UTF8中取出字串中特定的字數@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-10-23 17:49:20 最後編修
2017-08-12 22:04:54 By 張○○
 

一個字串可能帶有 html的TAG,多餘的空白,無意義的字元,或者為了存到資料庫中而加上的反斜線,若要取出特定的字數,就得把這些內容給篩選掉

因此我撰寫一個簡單的過濾函數

function StubUTF8String($str, $length=100){
  $str = stripslashes( $str );
  $str = strip_tags( $str);    //拿掉HTML的Tag
  $str = preg_replace('/[\n\r\t]/', ' ', $str);
  $str = preg_replace('/\s(?=\s)/', '', $str);
  $str = trim($str);
  return mb_substr( $str, 0, $length, "UTF-8");
}

第2-3行 把反斜線拿掉,移除html tag
第4行 把換行、TAB、行首字元改為空白' '
第5行 移除重覆的空白
第6行 移除頭尾的空白

這樣子基本上就沒有什麼大問題,但有一個小問題就是切英文字可能會把最後一個單字正好切斷。所以得加一個檢查,先少切一個字元,如果字串最後的字元是英文+數字,則把他取代掉。舉例來說,假設字串是這樣:

$str= "中國字英文<span style=\"color:#123455\">一二三四五</span>A running dog rams into a sleeping elephant.";

若要取長度11,則切的時候就切到第12位的地方,會是一個空白:

$str= "中國字英文一二三四五A ";

再把字串尾端的空白清掉就好。

如要要切長度12,則切13位,可以發現running 這個字被切破了,只剩一個'r':

$str= "中國字英文一二三四五A r";

發現第13 位是英文字母,那從第13位開始往前刪掉直到遇到非字母或數字即可。

這樣子還會有一個問題,就是取回的字串可能比原來的短,這也是沒辦法的事,畢竟切一半的英文字或數字是不行的。

但如果正好切斷的地方是國字,那麼少切一位的結果就回傳的中文字會多一個,因此最後還要多一個檢查,當回傳結果多一位時,要把他刪掉。

改寫後的程式,這樣不論切中切英都不會有問題了:

函式

/**
    *  StubUTF8String() -- UTF8下取出字串中特定的字數
    * @param string $str 傳入的字串
    * @param  int $length 取出的字數
    * @return 取回的字串
*/
function StubUTF8String($str, $length=40){
  $str = stripslashes( $str );
  $str = strip_tags( $str);    //拿掉HTML的Tag
  $str = preg_replace('/[\n\r\t]/', ' ', $str);
  $str = preg_replace('/\s(?=\s)/', '', $str);
  $str = mb_substr( $str, 0, $length+1, "UTF-8");
  $str = preg_replace('/[a-zA-Z]+$/', '', $str);
  $str = trim($str);
  if(mb_strlen($str)>$length)$str= mb_substr( $str, 0, -1, "UTF-8");
  return $str;
}

叫用

$str= "中國字英文 <span style=\"color:#123455\">一二三四五
六七八九十</span>A running dog ram into a sleeping elephant.";
print StubUTF8String($str,32);

輸出結果

中國字英文 一二三四五 六七八九十A running dog

多個空白和換行都被取代為一個空白' ',ram這個字取不完整捨棄,最後輸出共30個字元


編修 2009-10-28 23:36:03

END

你可能感興趣的文章

[PHP] 如何寫callback function 召回函數(回呼函數) PHP如何寫召回函數或回呼函數(callback function)?

[PHP] 檢查IP是否在某個網段內 mtachcidr 要檢查IP是否在某個網段內,要寫幾行?10行?5行? 不用,只要2行。以下是我寫的 code /** * matchCI

[CodeIgniter 3] 自寫找不到頁面(page404)的方法 使用CI3框架中如果找不到頁面,就會導到一個自定的404頁面,該怎麼做?

[PHP] CodeIgniter 3+pure+smarty安裝及環境設置1/2 PHP framework CodeIgniter 3+ pure CSS +smarty Template Engine的整合

[phpmyadmin] 錯誤:您應升級到 MySQL 5.5.0 或更新版本 使用phpmyadmin4出現錯誤:您應升級到 MySQL 5.5.0 或更新版本的解決方式

利用 php 木馬作為駭客攻擊的手法 利用 php 木馬作為駭客攻擊的手法

我有話要說

>>

限制:留言最高字數1000字。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

使用Google尋找你的手機 這近發現google竟然可以用來找android的手機,而且不需要經過什麼設定或安裝軟體。

一個邏輯的錯誤刪了全部檔案的經驗 今天本來想做一件很簡單的事,但卻足足浪費我多一倍的時間,再加上刪掉我全部的檔案,原因只是因為我自己的邏輯錯誤。

精讚的版面變化 ▓此文僅作為舊文的記錄▓ 這篇文章為了紀念改版完成而撰寫。 原本的部落格是民國97年的作品,那時還是用舊有的技術來寫,很

APACHE的記錄檔格式 LogFormat 語法 在APACHE中有定義一些記錄的語法模版 在 /etc/httpd/conf/httpd.conf 中: LogForm

[CodeIgniter 3] 資料庫的使用方法整理2/2 CI3 承襲 CI2,有很多的builder class可以用,依各人的使用習慣,有人喜歡一堆sql字串,有人喜歡用helper