本文實(shí)例講述了php字符串截取函數(shù)mb_substr用法。分享給大家供大家參考,具體如下:
string mb_substr ( string $str , int $start [, int $length = NULL [, string $encoding = mb_internal_encoding() ]] )-截取字符串
(PHP 4 >= 4.0.6, PHP 5)
$str 要獲取字符串的目標(biāo)字符串(字符串起始位置為0)
$start,$str中要使用的第一個字符的位置
$length,獲取的子字符串的長度(注意不是結(jié)束位置)
$encoding,可指定字符編碼(一般用于處理中文字符時使用,同時這個問題碰到的非常多)
示例:
?php
mb_internal_encoding ("UTF-8"); //如果把UTF-8改為編碼,下面針對于中文字符串處理的值會改變。
echo mb_internal_encoding().""; //獲取字符編碼為ISO-8859-1
echo mb_substr('abcdefghijk',0,9).""; //abcdefghi
echo mb_substr('abcdefghijk',1,5).""; //bcdef
echo mb_substr('我們都是中國人',0,9).""; //我們都是中國人
echo mb_substr('我們都是中國人',0,9,'gb2312').""; //我們都是中
echo mb_substr('我們都是中國人',0,9,'utf-8'); //我們都是中國人
?>
總結(jié):
1、在處理英文字符串的時候,該函數(shù)的第四個參數(shù)($encoding)可以忽略。
2、在處理中文字符串的時候,就要小心了,一定要考慮編碼問題,編碼不同,中文的值也不同。
3、在中文字符串導(dǎo)入數(shù)據(jù)庫時,就顯得更為重要了。
4、處理字符串或文本的編碼能力,是衡量程序員功力的一項(xiàng)標(biāo)準(zhǔn)。
補(bǔ)充:substr和mb_substr的區(qū)別
異同點(diǎn):
兩個函數(shù)都是截取字符串的長度,不同的是mb_substr
可以針對多字節(jié)編碼的漢字進(jìn)行截取,從而防止亂碼的出現(xiàn)
實(shí)例說明:
示例1:
?php
$chuan="我是中國人!";
echo substr($chuan,0,3);
echo 'br />';
echo mb_substr($chuan,0,3,'utf8');
?>
運(yùn)行結(jié)果:
我
我是中
在utf8編碼下,由于一個漢字占3個字節(jié),所以第一個輸出的是: 我
第二個輸出的是: 我是中
示例2:
?php
$chuan="我是中國人!";
echo substr($chuan,0,-4);
echo 'br />';
echo mb_substr($chuan,0,-2,'utf8');
?>
運(yùn)行結(jié)果:
我是中國
我是中國
兩個輸出的都是: 我是中國
第一個長度為負(fù)4,就會省略掉!和人,從零開始,就會包括我是中國
第二個同理
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php常用函數(shù)與技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- php生成隨機(jī)數(shù)/生成隨機(jī)字符串的方法小結(jié)【5種方法】
- php將字符串轉(zhuǎn)換為數(shù)組實(shí)例講解
- PHP生成隨機(jī)字符串實(shí)例代碼(字母+數(shù)字)
- PHP中將一個字符串部分字符用星號*替代隱藏的實(shí)現(xiàn)代碼
- php常用字符串長度函數(shù)strlen()與mb_strlen()用法實(shí)例分析
- PHP 通過Socket收發(fā)十六進(jìn)制數(shù)據(jù)的實(shí)現(xiàn)代碼
- PHP函數(shù)篇詳解十進(jìn)制、二進(jìn)制、八進(jìn)制和十六進(jìn)制轉(zhuǎn)換函數(shù)說明
- PHP字符串和十六進(jìn)制如何實(shí)現(xiàn)互相轉(zhuǎn)換