php字符串常用函數(shù)
數(shù)組、字符串和數(shù)據(jù)庫(kù)是我們函數(shù)里面最、最、最常用的三類函數(shù),數(shù)組和數(shù)據(jù)庫(kù)我們現(xiàn)在還沒有講到,等講到的時(shí)候我們?cè)賮?lái)和大家細(xì)說(shuō)。
當(dāng)然PHP的字符串函數(shù)也有很多。我們最常使用的兩個(gè)系列的字符串:
????1.單字節(jié)字符串處理函數(shù)
????2.多字節(jié)字符串處理函數(shù)
????3.字符串編碼轉(zhuǎn)換函數(shù)
我們來(lái)說(shuō)說(shuō)為什么要學(xué)這么多函數(shù):
????1.我們學(xué)的是中文,是雙字節(jié)或者三字節(jié)的。老外的函數(shù)只能處理英文和數(shù)字這些單字節(jié)的字符串處理不鳥中文。達(dá)不到我們的功能需求
????2.有的時(shí)候需要做不同字符編碼間的轉(zhuǎn)換,例如:把GBK的轉(zhuǎn)為UTF-8
????3.英文這些字符在電腦里又是必須要處理的
因此,我們要學(xué)三個(gè)類型的常用字符串函數(shù)。
我們來(lái)貼個(gè)PHP手冊(cè)的鏈接給大家看看:
看到這鏈接里面的手冊(cè)是不是被嚇的不行?
當(dāng)然,你不用學(xué)這么多。PHP中文網(wǎng)已經(jīng)幫你把最常用的,需要強(qiáng)制背訟的準(zhǔn)備好了。
之前都教過大家用,那你開始背函數(shù)吧。
PHP常用函數(shù):
函數(shù)名 | 描述 | 實(shí)例 |
---|---|---|
trim() | 刪除字符串兩端的空格或其他預(yù)定義字符 | "$str = "rnHello World!rn"; echo trim($str); |
rtrim() | 刪除字符串右邊的空格或其他預(yù)定義字符 | "$str = "Hello World!nn"; echo rtrim($str);" |
chop() | rtrim()的別名 | 同上 |
ltrim() | 刪除字符串左邊的空格或其他預(yù)定義字符 | "$str = "rnHello World!"; echo ltrim($str);" |
dirname() | 回路徑中的目錄部分(我們把它歸在了字符串函數(shù)里了) | echo dirname("c:/testweb/home.php"); |
str_pad() | 把字符串填充為指定的長(zhǎng)度 | $str = "Hello World"; echo str_pad($str,20,"."); |
str_repeat() | 重復(fù)使用指定字符串 | echo str_repeat(".",13); |
str_split() | 把字符串分割到數(shù)組中 | print_r(str_split("Hello")); |
strrev() | 反轉(zhuǎn)字符串 | echo strrev("Hello World!"); |
wordwrap() | 按照指定長(zhǎng)度對(duì)字符串進(jìn)行折行處理 | "$str = ""An example on a long word is: Supercalifragulistic""; echo wordwrap($str,15);" |
str_shuffle() | 隨機(jī)地打亂字符串中所有字符 | echo str_shuffle("Hello World"); |
parse_str() | 將字符串解析成變量 | "parse_str("id=23&name=John%20Adams",$myArray); print_r($myArray);" |
number_format() | 通過千位分組來(lái)格式化數(shù)字 | "echo number_format("1000000"); echo number_format("1000000",2); echo number_format("1000000",2,"","",""."");" |
strtolower() | 字符串轉(zhuǎn)為小寫 | echo strtolower("Hello WORLD!"); |
strtoupper() | 字符串轉(zhuǎn)為大寫 | echo strtoupper("Hello WORLD!"); |
ucfirst() | 字符串首字母大寫 | echo ucfirst("hello world"); |
ucwords() | 字符串每個(gè)單詞首字符轉(zhuǎn)為大寫 | echo ucwords("hello world"); |
htmlentities() | 把字符轉(zhuǎn)為HTML實(shí)體 | $str = ""John & 'Adams'""; echo htmlentities($str, ENT_COMPAT); |
htmlspecialchars() | 預(yù)定義字符轉(zhuǎn)html編碼 | |
nl2br() | n轉(zhuǎn)義為 標(biāo)簽 | echo nl2br("One line.nAnother line."); |
strip_tags() | 剝?nèi)?HTML、XML 以及 PHP 的標(biāo)簽 | echo strip_tags("Hello world!"); |
addcslashes() | 在指定的字符前添加反斜線轉(zhuǎn)義字符串中字符 | $str = ""Hello, my name is John Adams." echo $str; echo addcslashes($str,'m');" |
stripcslashes() | 刪除由addcslashes()添加的反斜線 | echo stripcslashes("Hello, my name is Kai Jim."); |
addslashes() | 指定預(yù)定義字符前添加反斜線 | $str = "Who's John Adams?";echo addslashes($str); |
stripslashes() | 刪除由addslashes()添加的轉(zhuǎn)義字符 | echo stripslashes("Who's John Adams?"); |
quotemeta() | 在字符串中某些預(yù)定義的字符前添加反斜線 | $str = "Hello world. (can you hear me?)"; echo quotemeta($str); |
chr() | 從指定的 ASCII 值返回字符 | echo chr(052); |
ord() | 返回字符串第一個(gè)字符的 ASCII值 | echo ord("hello"); |
strcasecmp() | 不區(qū)分大小寫比較兩字符串 | echo strcasecmp("Hello world!","HELLO WORLD!"); |
strcmp() | 區(qū)分大小寫比較兩字符串 | |
strncmp() | 比較字符串前n個(gè)字符,區(qū)分大小寫 | |
strncasecmp() | 比較字符串前n個(gè)字符,不區(qū)分大小寫 | int strncasecmp ( string $str1 , string $str2 , int $len ) |
strnatcmp() | 自然順序法比較字符串長(zhǎng)度,區(qū)分大小寫 | int strnatcmp ( string $str1 , string $str2 ) |
strnatcasecmp() | 自然順序法比較字符串長(zhǎng)度,不區(qū)分大小寫 | int strnatcasecmp ( string $str1 , string $str2 ) |
chunk_split() | 將字符串分成小塊 | str chunk_split(str $body[,int $len[,str $end]]) |
strtok() | 切開字符串 | str strtok(str $str,str $token) |
explode() | 使用一個(gè)字符串為標(biāo)志分割另一個(gè)字符串 | array explode(str $sep,str $str[,int $limit]) |
implode() | 同join,將數(shù)組值用預(yù)訂字符連接成字符串 | string implode ( string $glue , array $pieces ) |
substr() | 截取字符串 | string substr ( string $string , int $start [, int $length ] ) |
str_replace() | 字符串替換操作,區(qū)分大小寫 | mix str_replace(mix $search,,mix $replace,mix $subject[,int &$num]) |
str_ireplace() | 字符串替換操作,不區(qū)分大小寫 | mix str_ireplace ( mix $search , mix $replace , mix $subject [, int &$count ] ) |
substr_count() | 統(tǒng)計(jì)一個(gè)字符串,在另一個(gè)字符串中出現(xiàn)次數(shù) | int substr_count ( string $haystack , string $needle [, int $offset = 0 [, int $length ]] ) |
substr_replace() | 替換字符串中某串為另一個(gè)字符串 | mixed substr_replace ( mixed $string , string $replacement , int $start [, int $length ] ) |
similar_text() | 返回兩字符串相同字符的數(shù)量 | int similar_text(str $str1,str $str2) |
strchr() | 返回一個(gè)字符串在另一個(gè)字符串中開始位置到結(jié)束的字符串 | string strstr ( string $str, string $needle , bool $before_needle ) |
strrchr() | 返回一個(gè)字符串在另一個(gè)字符串中最后一次出現(xiàn)位置開始到末尾的字符串 | string strrchr ( string $haystack , mixed $needle ) |
stristr() | 返回一個(gè)字符串在另一個(gè)字符串中開始位置到結(jié)束的字符串,不區(qū)分大小寫 | string stristr ( string $haystack , mixed $needle [, bool $before_needle = false ] ) |
strtr() | 轉(zhuǎn)換字符串中的某些字符 | string strtr ( string $str , string $from , string $to ) |
strpos() | 尋找字符串中某字符最先出現(xiàn)的位置 | int strpos ( string $haystack , mixed $needle [, int $offset = 0 ] ) |
stripos() | 尋找字符串中某字符最先出現(xiàn)的位置,不區(qū)分大小寫 | int stripos ( string $haystack , string $needle [, int $offset ] ) |
strrpos() | 尋找某字符串中某字符最后出現(xiàn)的位置 | int strrpos ( string $haystack , string $needle [, int $offset = 0 ] ) |
strripos() | 尋找某字符串中某字符最后出現(xiàn)的位置,不區(qū)分大小寫 | int strripos ( string $haystack , string $needle [, int $offset ] ) |
strspn() | 返回字符串中首次符合mask的子字符串長(zhǎng)度 | int strspn ( string $str1 , string $str2 [, int $start [, int $length ]] ) |
strcspn() | 返回字符串中不符合mask的字符串的長(zhǎng)度 | int strcspn ( string $str1 , string $str2 [, int $start [, int $length ]] ) |
str_word_count() | 統(tǒng)計(jì)字符串含有的單詞數(shù) | mix str_word_count(str $str,[]) |
strlen() | 統(tǒng)計(jì)字符串長(zhǎng)度 | int strlen(str $str) |
count_chars() | 統(tǒng)計(jì)字符串中所有字母出現(xiàn)次數(shù)(0..255) | mixed count_chars ( string $string [, int $mode ] ) |
md5() | 字符串md5編碼 | $str = "Hello"; echo md5($str) |
iconv | ||
mb_substr | 獲取字符串的部分 | string mb_substr ( string $str , int $start [, int $length = NULL [, string $encoding = mb_internal_encoding() ]] ) |
mb_http_output | 設(shè)置/獲取 HTTP 輸出字符編碼 | mixed mb_http_output ([ string $encoding = mb_http_output() ] ) |
mb_strlen | 獲取字符串的長(zhǎng)度 | mixed mb_strlen ( string $str [, string $encoding = mb_internal_encoding() ] ) |
iconv | 字符串按要求的字符編碼來(lái)轉(zhuǎn)換 | string iconv ( string $in_charset , string $out_charset , string $str ) |
iconv_substr | 截取字符串的部分 | |
iconv_get_encoding | 獲取 iconv 擴(kuò)展的內(nèi)部配置變量 | |
mb_substr_count | 統(tǒng)計(jì)字符串出現(xiàn)的次數(shù) | |
mb_check_encoding | 檢查字符串在指定的編碼里是否有效 | |
mb_strrpos | 查找字符串在一個(gè)字符串中最后出現(xiàn)的位置 | |
mb_split | 使用正則表達(dá)式分割多字節(jié)字符串 | |
parse_url | 解釋URL成為一個(gè)數(shù)組 |
注:mb_* 和iconv_* 他們可以處理多字節(jié)字符,例如:中文。
中文主要用的是GBK和utf-8兩種編碼格式。
GBK和utf-8是兩個(gè)不同的編碼委員會(huì)對(duì)于漢字進(jìn)行的編碼的標(biāo)準(zhǔn)。
他們規(guī)定GBK是雙字節(jié),也就是一個(gè)漢字占用2Bytes。
utf-8是三字節(jié),一個(gè)漢字占用三個(gè)字節(jié)長(zhǎng)度的存儲(chǔ)空間。