PHP處理字符串的能力非常強(qiáng)大,方法也是多種多樣,但有的時(shí)候你需要選擇一種最簡(jiǎn)單且理想的解決方法,文章列舉了10個(gè)PHP中常見(jiàn)的字符串處理案例,并提供了相對(duì)應(yīng)的最理想的處理方法.

1.確定一個(gè)字符串的長(zhǎng)度

這是文章中最明顯的一個(gè)例子,其中的問(wèn)題是我們?nèi)绾蝸?lái)確定一個(gè)字符串的長(zhǎng)度,這里我們不能不提的就是strlen()函數(shù):

$text = "sunny day"; $count = strlen($text); // $count = 9

2.截取文本,創(chuàng)建一個(gè)摘要.

新聞性質(zhì)的網(wǎng)站通常會(huì)截取一個(gè)大約200字左右的段落,并在次段落的末尾加上省略號(hào)來(lái)形成一個(gè)摘要,這時(shí),你可以使用substr_replace()函數(shù)來(lái)實(shí)現(xiàn)此功能,由于篇幅的原因,這里只演示對(duì)40個(gè)字符的限制:

$article = "BREAKING NEWS: In ultimate irony, man bites dog.";

$summary = substr_replace($article, "...", 40);

$summary = "BREAKING NEWS:In ultimate irony, man bi..."

3.計(jì)算字符串中的字符和單詞數(shù)

相信您經(jīng)常會(huì)看到一些博客或者新聞?lì)愇恼?來(lái)總結(jié)文章的總字?jǐn)?shù),或者我們也經(jīng)??吹揭恍┩陡宓囊?在一定的字?jǐn)?shù)范圍內(nèi),這時(shí),你可以使用str_word_count()函數(shù)來(lái)計(jì)算文章字?jǐn)?shù)的總和:

$article = "BREAKING NEWS: In ultimate irony, man bites dog.";

$wordCount = str_word_count($article); // $wordCount = 8

有的時(shí)候你需要更加嚴(yán)格的控制投稿者的使用空間,例如一些批注等等,如果你想知道有多少個(gè)字符來(lái)組成一個(gè)數(shù)組,請(qǐng)使用count_chars()函數(shù).

4.解析CSV文件

數(shù)據(jù)通常是以逗號(hào)分隔的形式存儲(chǔ)在文件中的(如一個(gè)已知的CSV文件),CSV文件使用一個(gè)逗號(hào)或者類似于預(yù)定義符號(hào),將每列字符串組成一個(gè)單獨(dú)的行,你可能經(jīng)常創(chuàng)建PHP腳本來(lái)導(dǎo)入這些數(shù)據(jù),或者解析出你所需要的東西,這些年來(lái),我也看到過(guò)很多解析CSV文件的方法,最常見(jiàn)的就是使用fgets()和explode()函數(shù)的組合來(lái)讀取和解析文件,然而,最簡(jiǎn)單的方法是使用一個(gè)函數(shù)來(lái)解決問(wèn)題,但它并不屬于PHP的字符串處理庫(kù)里的一部分:fgetcsv()函數(shù),使用fopen()和fgetcsv()函數(shù),我們能夠很容易的解析這個(gè)文件,同時(shí)檢索出每個(gè)聯(lián)系人的名字:

  1. $fh = fopen("contacts.csv""r");   
  2.  while($line = fgetcsv($fh, 1000, ","))    
  3. echo "Contact: {$line[1]}"; } 

5.轉(zhuǎn)換成一個(gè)字符串?dāng)?shù)組

某些時(shí)候,你可能需要?jiǎng)?chuàng)建CSV文件,同時(shí)又在這些文件中進(jìn)行讀取,這就意味著你需要將那些同逗號(hào)分隔的字符串轉(zhuǎn)換成數(shù)據(jù),如果這些數(shù)據(jù)最初是從數(shù)據(jù)庫(kù)檢索出的,那么它很可能會(huì)只給您提供一個(gè)數(shù)組,這時(shí),您可以使用implode()函數(shù),將這些字符串轉(zhuǎn)換成一個(gè)數(shù)組:

$csv = implode(",", $record);

6.將網(wǎng)址轉(zhuǎn)換成超鏈接

目前許多WYSIWYG編輯器提供的工具欄,都允許用戶標(biāo)記文本,包括超鏈接,但是,當(dāng)內(nèi)容呈現(xiàn)到頁(yè)面上時(shí),你可以很容易的自動(dòng)執(zhí)行此過(guò)程,同時(shí)保證您不出現(xiàn)額外的錯(cuò)誤,要轉(zhuǎn)換成超鏈接的URL,你可以使用preg_replace()函數(shù),它可以按照正則表達(dá)式來(lái)搜索一個(gè)字符串,并定義了URL的結(jié)構(gòu):

  1. $url = "LanFengye, LLC (http://www.phpfensi.com)";    
  2. $url = preg_replace("/http://([A-z0-9./-]+)/""$0"$url);    
  3. // $url = "LanFengye, LLC (http://www.phpfensi.com)" 

7.從一個(gè)字符串中去除HTML標(biāo)簽

作為Web開(kāi)發(fā)人員,其中的一個(gè)主要工作就是要確保用戶輸入中不含有危險(xiǎn)字符,如果有,這會(huì)導(dǎo)致SQL注入或腳本攻擊,PHP語(yǔ)言中包含了很多安全方面的功能,這些功能能夠幫助你過(guò)濾數(shù)據(jù),包括延長(zhǎng)過(guò)濾器,例如,你可以允許用戶中帶有一些基本的HTML語(yǔ)句,包括一些注釋,實(shí)現(xiàn)這個(gè)功能,你可以使用帶有檢查功能函數(shù):strip_tags(),它在默認(rèn)的情況下是從字符串中刪除所有的HTML標(biāo)簽,但同時(shí)也允許覆蓋默認(rèn)或者你指定的標(biāo)簽,例如,在下面的例子中,你可以除去所有的標(biāo)簽:

$text = strip_tags($input, "");

8.比較兩個(gè)字符串

比較兩個(gè)字符串,以確保它們是相同的,例如,判斷用戶第一次與第二次輸入的密碼是否相同,你可以使用substr_compare()函數(shù)來(lái)很容易的現(xiàn)實(shí):

  1. $pswd = "secret";    
  2. $pswd2 = "secret";    
  3. if (! strcmp($pswd$pswd2))    
  4. echo "The passwords are not identical!";   
  5.  } 

如果你想判斷兩個(gè)字符串不區(qū)分大小寫(xiě),可以使用strcasecmp()函數(shù).

9.轉(zhuǎn)換換行符

在本文中我介紹了如何輕松轉(zhuǎn)換成超超鏈接的URL,現(xiàn)在介紹nl2br()函數(shù),這個(gè)函數(shù)能夠幫助你將任何換行符轉(zhuǎn)換成HTML標(biāo)簽.

$comment = nl2br($comment);

10.應(yīng)用自動(dòng)換行

應(yīng)用自動(dòng)換行,你可以使用PHP中的這個(gè)函數(shù):wordwrap():

  1. $speech = "Four score and seven years ago our fathers brought forth,    
  2. upon this continent, a new nation, conceived in Liberty,    
  3. and dedicated to the proposition that all men are created equal.";    
  4.    
  5. echo wordwrap($speech, 30);執(zhí)行上面的代碼,結(jié)果是: 
  6.  
  7. Four score and seven years ago our fathers brought forth, upon this continent, a new nation, conceived in Liberty, and dedicated to the proposition that all men are created equal. 

addcslashes — 為字符串里面的部分字符添加反斜線轉(zhuǎn)義字符

addslashes — 用指定的方式對(duì)字符串里面的字符進(jìn)行轉(zhuǎn)義
bin2hex — 將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換成十六進(jìn)制表示
chop — rtrim() 的別名函數(shù)
chr — 返回一個(gè)字符的ASCII碼
chunk_split — 按一定的字符長(zhǎng)度將字符串分割成小塊
convert_cyr_string — 將斯拉夫語(yǔ)字符轉(zhuǎn)換為別的字符
convert_uudecode — 解密一個(gè)字符串
convert_uuencode — 加密一個(gè)字符串
count_chars — 返回一個(gè)字符串里面的字符使用信息
crc32 — 計(jì)算一個(gè)字符串的crc32多項(xiàng)式
crypt — 單向散列加密函數(shù)
echo — 用以顯示一些內(nèi)容
explode — 將一個(gè)字符串用分割符轉(zhuǎn)變?yōu)橐粩?shù)組形式
fprintf — 按照要求對(duì)數(shù)據(jù)進(jìn)行返回,并直接寫(xiě)入文檔流
get_html_translation_table — 返回可以轉(zhuǎn)換的HTML實(shí)體
hebrev — 將Hebrew編碼的字符串轉(zhuǎn)換為可視的文本
hebrevc — 將Hebrew編碼的字符串轉(zhuǎn)換為可視的文本
html_entity_decode — htmlentities ()函數(shù)的反函數(shù),將HTML實(shí)體轉(zhuǎn)換為字符
htmlentities — 將字符串中一些字符轉(zhuǎn)換為HTML實(shí)體
htmlspecialchars_decode —htmlspecialchars()函數(shù)的反函數(shù),將HTML實(shí)體轉(zhuǎn)換為字符
htmlspecialchars — 將字符串中一些字符轉(zhuǎn)換為HTML實(shí)體
implode — 將數(shù)組用特定的分割符轉(zhuǎn)變?yōu)樽址?
join — 將數(shù)組轉(zhuǎn)變?yōu)樽址琲mplode()函數(shù)的別名
levenshtein — 計(jì)算兩個(gè)詞的差別大小
localeconv — 獲取數(shù)字相關(guān)的格式定義
ltrim — 去除字符串左側(cè)的空白或者指定的字符
md5_file — 將一個(gè)文件進(jìn)行MD5算法加密
md5 — 將一個(gè)字符串進(jìn)行MD5算法加密
metaphone — 判斷一個(gè)字符串的發(fā)音規(guī)則
money_format — 按照參數(shù)對(duì)數(shù)字進(jìn)行格式化的輸出
nl_langinfo — 查詢語(yǔ)言和本地信息
nl2br — 將字符串中的換行符“n”替換成“<br/>”
number_format — 按照參數(shù)對(duì)數(shù)字進(jìn)行格式化的輸出
ord — 將一個(gè)ASCII碼轉(zhuǎn)換為一個(gè)字符
parse_str — 把一定格式的字符串轉(zhuǎn)變?yōu)樽兞亢椭?
print — 用以輸出一個(gè)單獨(dú)的值
printf — 按照要求對(duì)數(shù)據(jù)進(jìn)行顯示
quoted_printable_decode — 將一個(gè)字符串加密為一個(gè)8位的二進(jìn)制字符串
quotemeta — 對(duì)若干個(gè)特定字符進(jìn)行轉(zhuǎn)義
rtrim — 去除字符串右側(cè)的空白或者指定的字符
setlocale — 設(shè)置關(guān)于數(shù)字,日期等等的本地格式
sha1_file — 將一個(gè)文件進(jìn)行SHA1算法加密
sha1 — 將一個(gè)字符串進(jìn)行SHA1算法加密
similar_text — 比較兩個(gè)字符串,返回系統(tǒng)認(rèn)為的相似字符個(gè)數(shù)
soundex — 判斷一個(gè)字符串的發(fā)音規(guī)則
sprintf — 按照要求對(duì)數(shù)據(jù)進(jìn)行返回,但是不輸出
sscanf — 可以對(duì)字符串進(jìn)行格式化
str_ireplace — 像str_replace()函數(shù)一樣匹配和替換字符串,但是不區(qū)分大小寫(xiě)
str_pad — 對(duì)字符串進(jìn)行兩側(cè)的補(bǔ)白
str_repeat — 對(duì)字符串進(jìn)行重復(fù)組合
str_replace — 匹配和替換字符串
str_rot13 — 將字符串進(jìn)行ROT13加密處理
str_shuffle — 對(duì)一個(gè)字符串里面的字符進(jìn)行隨機(jī)排序
str_split — 將一個(gè)字符串按照字符間距分割為一個(gè)數(shù)組
str_word_count — 獲取字符串里面的英文單詞信息
strcasecmp — 對(duì)字符串進(jìn)行大小比較,不區(qū)分大小寫(xiě)
strchr — 通過(guò)比較返回一個(gè)字符串的部分strstr()函數(shù)的別名
strcmp — 對(duì)字符串進(jìn)行大小比較
strcoll – 根據(jù)本地設(shè)置對(duì)字符串進(jìn)行大小比較
strcspn — 返回字符連續(xù)非匹配長(zhǎng)度的值
strip_tags — 去除一個(gè)字符串里面的HTML和PHP代碼
stripcslashes — 反轉(zhuǎn)義addcslashes()函數(shù)轉(zhuǎn)義處理過(guò)的字符串
stripos — 查找并返回首個(gè)匹配項(xiàng)的位置,匹配不區(qū)分大小寫(xiě)
stripslashes — 反轉(zhuǎn)義addslashes()函數(shù)轉(zhuǎn)義處理過(guò)的字符串
stristr — 通過(guò)比較返回一個(gè)字符串的部分,比較時(shí)不區(qū)分大小寫(xiě)
strlen — 獲取一個(gè)字符串的編碼長(zhǎng)度
strnatcasecmp — 使用自然排序法對(duì)字符串進(jìn)行大小比較,不區(qū)分大小寫(xiě)
strnatcmp — 使用自然排序法對(duì)字符串進(jìn)行大小比較
strncasecmp — 對(duì)字符串的前N個(gè)字符進(jìn)行大小比較,不區(qū)分大小寫(xiě)
strncmp — 對(duì)字符串的前N個(gè)字符進(jìn)行大小比較
strpbrk — 通過(guò)比較返回一個(gè)字符串的部分
strpos — 查找并返回首個(gè)匹配項(xiàng)的位置
strrchr — 通過(guò)從后往前比較返回一個(gè)字符串的部分
strrev — 將字符串里面的所有字母反向排列
strripos — 從后往前查找并返回首個(gè)匹配項(xiàng)的位置,匹配不區(qū)分大小寫(xiě)
strrpos – 從后往前查找并返回首個(gè)匹配項(xiàng)的位置
strspn — 匹配并返回字符連續(xù)出現(xiàn)長(zhǎng)度的值
strstr — 通過(guò)比較返回一個(gè)字符串的部分
strtok — 用指定的若干個(gè)字符來(lái)分割字符串
strtolower — 將字符串轉(zhuǎn)變?yōu)樾?xiě)
strtoupper –將字符串轉(zhuǎn)變?yōu)榇髮?xiě)
strtr — 對(duì)字符串比較替換
substr_compare — 對(duì)字符串進(jìn)行截取后的比較
substr_count — 計(jì)算字符串中某字符段的出現(xiàn)次數(shù)
substr_replace — 對(duì)字符串中的部分字符進(jìn)行替換
substr — 對(duì)字符串進(jìn)行截取
trim — 去除字符串兩邊的空白或者指定的字符
ucfirst — 將所給字符串的第一個(gè)字母轉(zhuǎn)換為大寫(xiě)
ucwords — 將所給字符串的每一個(gè)英文單詞的第一個(gè)字母變成大寫(xiě)
vfprintf — 按照要求對(duì)數(shù)據(jù)進(jìn)行返回,并直接寫(xiě)入文檔流
vprintf — 按照要求對(duì)數(shù)據(jù)進(jìn)行顯示
vsprintf — 按照要求對(duì)數(shù)據(jù)進(jìn)行返回,但是不輸出
wordwrap — 按照一定的字符長(zhǎng)度分割字符串
轉(zhuǎn)載請(qǐng)注明來(lái)源:php字符串處理函數(shù)詳解

  哈爾濱品用軟件有限公司致力于為哈爾濱的中小企業(yè)制作大氣、美觀的優(yōu)秀網(wǎng)站,并且能夠搭建符合百度排名規(guī)范的網(wǎng)站基底,使您的網(wǎng)站無(wú)需額外費(fèi)用,即可穩(wěn)步提升排名至首頁(yè)。歡迎體驗(yàn)最佳的哈爾濱網(wǎng)站建設(shè)。