php字符串截取函數(shù)mb_substr用法實例分析
本文實例講述了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 要獲取字符串的目標字符串(字符串起始位置為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、處理字符串或文本的編碼能力,是衡量程序員功力的一項標準。
補充:substr和mb_substr的區(qū)別
異同點:
兩個函數(shù)都是截取字符串的長度,不同的是mb_substr可以針對多字節(jié)編碼的漢字進行截取,從而防止亂碼的出現(xiàn)
實例說明:
示例1:
<?php $chuan="我是中國人!"; echo substr($chuan,0,3); echo '<br />'; echo mb_substr($chuan,0,3,'utf8'); ?>
運行結(jié)果:
我
我是中
在utf8編碼下,由于一個漢字占3個字節(jié),所以第一個輸出的是: 我
第二個輸出的是: 我是中
示例2:
<?php $chuan="我是中國人!"; echo substr($chuan,0,-4); echo '<br />'; echo mb_substr($chuan,0,-2,'utf8'); ?>
運行結(jié)果:
我是中國
我是中國
兩個輸出的都是: 我是中國
第一個長度為負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è)計有所幫助。
相關(guān)文章
win10 apache配置虛擬主機后localhost無法使用的解決方法
這篇文章主要為大家詳細介紹了win10 apache配置虛擬主機后localhost無法使用的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01
php+mysql+ajax實現(xiàn)單表多字段多關(guān)鍵詞查詢的方法
這篇文章主要介紹了php+mysql+ajax實現(xiàn)單表多字段多關(guān)鍵詞查詢的方法,涉及php基于ajax的數(shù)據(jù)庫查詢、表格操作等相關(guān)技巧,需要的朋友可以參考下2017-04-04
php數(shù)組函數(shù)序列之a(chǎn)rray_search()- 按元素值返回鍵名
array_search() 函數(shù)與 in_array() 一樣,在數(shù)組中查找一個鍵值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false2011-11-11

