PHP處理字串的能力非常強大,方法也是多種多樣,但有的時候你需要選擇一種最簡單且理想的解決方法,文章列舉了10個PHP中常見的字符串處理案例,並提供了相對應的最理想的處理方法.
1.確定一個字符串的長度
這是文章中最明顯的一個例子,其中的問題是我們如何來確定一個字符串的長度,這裡我們不能不提的就是strlen()函數:
$text = "sunny day"; $count = strlen($text); // $count = 9
2.截取文字,建立一個摘要.
新聞性質的網站通常會截取一個大約200字左右的段落,並在次段落的末尾加上省略號來形成一個摘要,這時,你可以使用substr_replace()函數來實現此功能,由於篇幅的原因,這裡只演示對40個字元的限制:
$article = "BREAKING NEWS: In ultimate irony, man bites dog.";
$summary = substr_replace($article, "...", 40);
:In ultimate irony, man bi..."
3.計算字符串中的字符和單詞數
相信您經常會看到一些博客或新聞類文章,來總結文章的總字數,或者我們也經常看到一些投稿的要求,在一定的字數範圍內,這時,你可以使用str_word_count()函數來計算文章字數的總和:
$article = "BREAKING NEWS: In ultimate irony, man bites dog.";
$wordCount = str_word_count($article); // $wordCount = 8
有的時候你需要更加嚴格的控制投稿者的使用空間,例如一些批註等等,如果你想知道有多少個字符來組成一個陣列,請使用count_chars()函數.
4.解析CSV檔案
資料通常是以逗號分隔的形式儲存在檔案中的(如一個已知的CSV檔案),CSV檔案使用一個逗號或類似預定義符號,將每列字串組成一個單獨的行,你可能經常創建PHP腳本來導入這些數據,或者解析出你所需要的東西,這些年來,我也看到過很多解析CSV文件的方法,最常見的就是使用fgets()和explode()函數的組合來讀取和解析文件,然而,最簡單的方法是使用一個函數來解決問題,但它並不屬於PHP的字符串處理庫裡的一部分:fgetcsv()函數,使用fopen()和fgetcsv()函數,我們能夠很容易的解析這個檔案,同時檢索出每個聯絡人的名字:
$fh = fopen("contacts.csv", "r ");
while($line = fgetcsv($fh, 1000, ","))
{ echo "Contact:
{ echo "Contact:
{ echo "Contact:
某些時候,你可能需要創建CSV文件,同時又在這些文件中進行讀取,這就意味著你需要將那些同逗號分隔的字符串轉換成數據,如果這些數據最初是從數據庫檢索出的,那麼它很可能會只給您一個數組,這時,您可以使用implode()函數,將這些字串轉換成一個數組:$csv = implode(",", $record); 6.將網址轉換成超連結目前許多WYSIWYG編輯器提供的工具列,都允許用戶標記文字,包括超連結,但是,當內容呈現到頁面上時,你可以很容易的自動執行此過程,同時保證您不出現額外的錯誤,要轉換成超連結的URL,你可以使用preg_replace()函數,它可以按照正規表示式來搜尋一個字串,並定義了URL的結構:$url = " LanFengye, LLC (http://www.phpfensi.com)"; $url = preg_replace("/http://([A-z0-9./-]+)/", "$0", $ url); // $url = "LanFengye, LLC (http://www.phpfensi.com)" 7.從一個字串中去除HTML標籤作為Web開發人員,其中的一個主要工作人員就是要確保用戶輸入中不含有危險字符,如果有,這會導致SQL注入或腳本攻擊,PHP語言中包含了很多安全方面的功能,這些功能能夠幫助你過濾數據,包括延長過濾器,例如,你可以允許使用者中帶有一些基本的HTML語句,包括一些註解,實現這個功能,你可以使用帶有檢查功能函數:strip_tags(),它在預設的情況下是從字串中刪除所有的HTML標籤,但同時也允許覆蓋預設或你指定的標籤,例如,在下面的例子中,你可以除去所有的標籤:$text = strip_tags($input, "");8.比較兩個字串比較兩個字串,以確保它們是相同的,例如,判斷用戶第一次與第二次輸入的密碼是否相同,你可以使用substr_compare()函數來很容易的現實:$pswd = "secret"; $pswd2 = "secret"; if (! strcmp($pswd, $pswd2)){ echo "The passwords are not identical!";
}
如果你想判斷兩個字串不區分大小寫介紹如何輕鬆轉換成超超連結的URL,現在介紹nl2br()函數,這個函數能夠幫助你將任何換行符轉換成HTML標籤.
$comment = nl2br($comment);
10.應用自動換行
應用自動換行,你可以使用PHP中的這個函數:wordwrap():
$speech = "Four score and seven years ago our nation, conceived in Liberty ,
and dedicated to the proposition that all men are created equal.";
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
addslashes — 用指定的方式對字串裡面的字元進行轉義bin2hex — 將二進位資料轉換成十六進位表示chop — rtrim() 的別名函數chr — 傳回一個字元的ASCII碼以一定的字元長度將字串分割成小塊convert_cyr_string — 將斯拉夫語字元轉換為別的字元convert_uudecode — 解密一個字串convert_uuencode — 加密一個字串count的字元使用資訊crc32 — 計算一個字串的crc32多項式crypt — 單向雜湊加密函數echo — 用以顯示一些內容explode — 將一個字串用符轉換為一數組形式fprintf — 按照要求對資料進行返回,並直接寫入文檔流get_html_translation_table — 返回可以轉換的HTML實體hebrev — 將Hebrew編碼的字串轉換為可視化的文字編碼hebrev — 將Hebrew編碼的字串轉換為可視化的文字編碼hebres — 將的字串轉換為可視的文字html_entity_decode — htmlentities ()函數的反函數,將HTML實體轉換為字元htmlentities — 將字串中某些字元轉換為HTML實體htmlspecialchars_decode —htmlspecialcharialdecode —html 函數的函數的反函數,將HTML實體轉換為字元htmlspecialchars — 將字串中某些字元轉換為HTML實體implode — 將陣列以特定的分割符轉換為字串join — 將陣列轉換為字串,implode ()函數的別名levenshtein — 計算兩個字的差別大小localeconv — 取得數字相關的格式定義ltrim — 移除字串左邊的空白或指定的字元md5_ltrim — 移除字串左邊的空白或指定的字元算法加密
md5 — 將一個字符串進行MD5算法加密
metaphone — 判斷一個字符串的發音規則
money_format — 按照參數對數字進行格式化的輸出
nl_langinfo — 查詢語言和本地信息
nl2br — 將字串中的換行符「n」替換成「
」
number_format — 依照參數對數字進行格式化的輸出
ord — 將一個ASCII碼轉換為一個字元
parse_str — 把一定格式的字串轉變為變數和值
print — 使用以輸出一個單獨的值
printf — 依照要求將資料顯示
quoted_printable_decode — 將一個字串加密為一個8位元的二進位字串
quotemeta — 對若干特定字元進行轉義
rtrim — 去除字串右側的空白或指定的字元
setlocale — 設定關於數字,日期等等的本地格式
sha1_file — 將一個檔案進行SHA1演算法加密
sha1 — 將一個字串進行SHA1演算法加密
similar_text — 比較兩個字串,傳回系統認為的相似字元個數
soundex — 判斷一個字串的發音規則
sprintf — 依照要求將資料傳回,但是不輸出
sscanf — 可以對字串進行格式化
str_ireplace — 像str_replace()函數一樣匹配和替換字串,但是不區分大小寫
str_pad — 對字串進行兩側的補白
str_repeat — 對字串進行重複組合
str_replace — 匹配和替換字串
str_rot13 — 將字串進行ROT13加密處理
str_shuffle — 對一個字串裡面的字元進行隨機排序
str_shuffle — 將一個字串裡面的字元進行隨機排序依字元間距分割為一個陣列str_word_count — 取得字串裡面的英文單字資訊
strcasecmp — 將字串進行大小比較,不區分大小寫
strchr — 透過比較傳回一個字串的部分strstr()函數的別名
strcmp — 對字元字串進行大小比較
strcoll – 依照本地設定對字串進行大小比較
strcspn — 傳回字元連續非符合長度的值
strip_tags — 移除一個字串裡面的HTML和PHP
stripcslashs — 反轉義cs addcslashes()函數轉義處理過的字串
stripos — 尋找並傳回首個符合項目的位置,符合不區分大小寫
stripslashes — 反轉義addslashes()函數轉義處理過的字串
stristr — 透過比較傳回一個字串的部分,比較時不區分大小寫
strlen — 取得一個字串的編碼長度
strnatcasecmp — 使用自然排序法對字串進行大小比較,不區分大小寫
strnatcmp — 使用自然排序法對字串進行大小比較
strncasecmp — 對字串的前N個字元進行大小比較,不區分大小寫
strncmp — 對字串的前N個字元進行大小比較
strpbrk —透過比較傳回一個字串的部分
strpos — 尋找並傳回首個符合項目的位置
strrchr — 透過從後往前比較傳回一個字串的部分
strrev — 將字串裡面的所有字母反向排列
strripos — 從後往前查找並返回首個匹配項的位置,匹配不區分大小寫
strrpos – 從後往前查找並返回首個匹配項的位置
strspn — 匹配並返回字符連續字符連續字符出現長度的值
strstr — 透過比較傳回字串的部分
strtok — 用指定的若干個字元來分割字串
strtolower — 將字串轉換為小寫
strtoupper –將字串轉換為大寫
strtr — 將字串比較替換
substr_compare — 對字串進行截取後的比較
substr_count — 計算字串中某字元段的出現次數
substr_replace — 將字串中的部分字元進行替換substr — 將字串截取
trim — 移除字串兩邊的空白或指定的字元
ucfirst — 將所給字串的第一個字母轉換為大寫
ucwords — 將所給字串的每一個英文單字的第一個字母變成大寫
vfprintf — 按照要求對資料進行返回,並直接寫入文檔流
vprintf — 按照要求對資料進行顯示
vsprintf — 按照要求對資料進行返回,但是不輸出
wordwrap — 依照一定的字元長度分割字串