從下文中我們可以知道字符串比較除了可以使用函數(shù)來進行比較之外,還可以使用==或===來進行字符比較了,下面本文章就字符串比較問題給各位總結(jié)一下.
比較字符串是任何編程語言的字符串處理功能中重要的特性之一,在PHP中除了可以使用比較運算符號(==、<或>)加以比較外,還提供了一系列的比較函數(shù),使PHP可以進行更復(fù)雜的字符串比較,如strcmp()、strcasecmp()和strnatcmp()等函數(shù).
1.按字節(jié)順序進行字符串比較
要按字節(jié)順序進行字符串的比較,可以使用strcmp()和strcasecmp()兩個函數(shù),其中函數(shù)strcasecmp()可以忽略字符串中字母的大小寫進行比較,這兩個函數(shù)的原型如下所示:
- in strcmp(string str1,string str2) //區(qū)分字符串中字母大小寫地比較
- int strcasecmp(string str1,string str2) //忽略字符串中字母大小寫地比較
這兩個函數(shù)的用法相似,都需要傳入進行比較的兩個字符串參數(shù),可以對輸入的str1和str2兩字符串,按照字節(jié)的ASCII值從兩個字符串的首字節(jié)開始比較,如果相等則進入下一個字節(jié)的比較,直至結(jié)束比較,返回以下三個值之一:
★如果str1等于str2則返回0.
★如果str1大于str2則返回1.
★如果str1小于str2則返回-1.
在下面的程序中通過比較后的返回值判斷兩個比較字符串大小,使用strcmp()函數(shù)區(qū)分字符串中字母大小寫的比較,使用strcasecmp()函數(shù)忽略字符串中字母大小寫的比較,當(dāng)然沒有實際意義,代碼如下所示:
- <?php
- $username = "Admin";
- $password = "lampBrother";
- //不區(qū)分大小寫的比較,如果兩個字符串相等返回0
- if(strcasecmp($userName,"admin")== 0){
- echo "用戶名存在";
- }
- //將兩個比較的字符串相應(yīng)的函數(shù)轉(zhuǎn)成全大寫或全小寫后,也可以實現(xiàn)不區(qū)分大小寫的比較
- if(strcasecmp(strtolower($userName),strtolower("admin")) == 0){
- echo "用戶名存在";
- }
- //開源軟件:Vevb.com
- //區(qū)分字符串中字母的大小寫比較
- switch(strcmp($password,"lampbrother")){
- case 0:
- echo "兩個字符串相等<br>"; break;
- case 1:
- echo "第一個字符串大于第二個字符串<br>"; break;
- case -1:
- echo "第一個字符串小于第二個字符串<br>"; break;
- }
- ?>
2.按自然排序進行字符串比較
除了可以按照字節(jié)位的字典順序進行比較外,PHP還提供了按照“自然排序”法對字符串進行比較,所謂自然排序,是指按照人們的日常生活中的思維習(xí)慣進行排序,即將字符串中的數(shù)字部分按照數(shù)字大小進行比較,例如按照字節(jié)比較時“4”大于“33”,因為“4”大于“33”中的第一個字符,而按照自然排序法則“33”大于“4”,使用strnatcmp()函數(shù)按自然排序法比較兩個字符串,該函數(shù)對大小寫敏感,其使用格式與strcmp()函數(shù)相似.
在下面的例子中,對一個數(shù)組中帶有數(shù)字的文件名,使用冒泡排序法通過兩種比較方法排序,代碼如下所示:
- <?php
- //定義一個包含數(shù)字值的數(shù)組
- $files = array("file11.txt","file22.txt","file1.txt","file2.txt");
- function mySort($arr,$select = false){
- for($i=0;$i<count($arr);$i++){
- for($j;$j<count($arr)-1;$j++){
- //如果第二個參數(shù)為ture則使用strcmp()函數(shù)比較大小
- if($select){
- //前后兩個值比較結(jié)果大于0則交換位置
- if(strcmp($arr[$j],$arr[j+1])>0){
- $tmp = $arr[$j];
- $arr[$j] = $arr[$j+1];
- $arr[$j+1] = $tmp;
- }
- //如果第二個參數(shù)為false則使用strnatcmp()函數(shù)比較大小
- }else{
- //如果比較結(jié)果大于0交換位置
- if(strnatcmp($arr[$j],$arr[$j+1])>0){
- $tmp = $arr[$j];
- $arr[$j] = $arr[$j+1];
- $arr[$j+1]; = $tmp;
- }
- }
- }
- }
- return $arr; //排序后的數(shù)組
- }
- print_r(mySort($files,true)); //選擇按字典順序排序: file1.txt file11.txt file2.txt file22.txt
- print_r(mySort($files,false)); //選擇按自然順序排序:file1.txt file2.txt file11.txt file22.txt
- ?>
在PHP中也提供了這個函數(shù)忽略大小寫的版本的函數(shù)strnatcasecmp()用法與strnatcmp()函數(shù)相同.
除了上面利用函數(shù)比較我們還可以使用“===”來判斷,至于它和“==”的區(qū)別,一般能用 !=, == 比較兩個對象是否相等,只所以說是兩個對象,是因為他們不一定全部為字符串,也能為整型等等.
如果用 !==,===(能看到多了一個等號)比較的話,兩個對象的類型要嚴格相等才能返回true;否則用==,!=則會將字符串自動轉(zhuǎn)換成相應(yīng)的類型,以便進行比較,代碼如下:
- 22 == "22"; // 返回 true
- 22 === "22"; // 返回false
正因為這樣,所以我們的程式時常會發(fā)生一些想不到的“意外”,代碼如下:
- 0 == "我愛你"; // 返回true
- 1 == "1 我愛你";// 返回true
還有一種比較方法:
- var_dump("1" == "1e0");
- var_dump("1" == "0x1");
- var_dump("20" == "2e1");
- var_dump("10" == " 0x0a");
等等;對,也許你會說在PHP手冊的附錄中有一部分關(guān)于這個問題的總結(jié),問題是,這只是知其然,那么所以然是什么呢?
今天就有一個網(wǎng)友問了我一個問題:
- var_dump("1" == "1e0"); //true
- var_dump("1" == "1ef"); //false
這兩個的結(jié)果為什么不一樣啊,也就是說,上面的等式a要成立,那么唯一的解釋就是PHP講他們雙發(fā)都當(dāng)作int來比較.
但是,var_dump(“1e0″),或者var_dump(“1″),都是string啊,因為PHP不區(qū)分類型,所以她采用一個策略,當(dāng)你的變量看起來是一個數(shù)字的時候,那么她就認為這個變量是一個數(shù)字.
簡單來說,numeric_string就是表示數(shù)字的字符串,也就是說,如下的比較結(jié)果都是真,代碼如下:
- var_dump("1" == "1e0");
- var_dump("1" == "0x1");
- var_dump("20" == "2e1");
- var_dump("10" == " 0x0a");
呵呵,讀者們遇到過這個問題的困擾么?代碼如下:
- if("608E-4234" == "272E-3063"){
- echo "oh shit! they're equal!\n";
- }else{
- echo "obviously, isn't?\n";
- }
PHP開發(fā)Tips:如果想要判斷兩個字符串是否相等,使用 === 而不是 ==.
新聞熱點
疑難解答