比較字串是任何程式語言的字串處理功能中重要的特性之一。在PHP中除了可以使用比較運算子號(==、<或>)加以比較外,還提供了一系列的比較函式,使PHP可以進行更復雜的字串比較。如strcmp()、strcasecmp()和strnatcmp()等函式。
1.按位元組順序進行字串比較
要按位元組順序進行字串的比較,可以使用strcmp()和strcasecmp()兩個函式,其中函式strcasecmp()可以忽略字串中字母的大小寫進行比較。這兩個函式的原型如下所示:
複製程式碼 程式碼如下:
in strcmp(string str1,string str2) //區分字串中字母大小寫地比較
int strcasecmp(string str1,string str2) //忽略字串中字母大小寫地比較
這兩個函式的用法相似,都需要傳入進行比較的兩個字串引數。可以對輸入的str1和str2兩字串,按照位元組的ASCII值從兩個字串的首位元組開始比較,如果相等則進入下一個位元組的比較,直至結束比較。返回以下三個值之一:
如果str1等於str2則返回0。
如果str1大於str2則返回1。
如果str1小於str2則返回-1。
在下面的程式中通過比較後的返回值判斷兩個比較字串大小。使用strcmp()函式區分字串中字母大小寫的比較,使用strcasecmp()函式忽略字串中字母大小寫的比較。當然沒有實際意義。程式碼如下所示:
複製程式碼 程式碼如下:
<?php
$username = "Admin";
$password = "lampBrother";
//不區分大小寫的`比較,如果兩個字串相等返回0
if(strcasecmp($userName,"admin")== 0){
echo "使用者名稱存在";
}
//將兩個比較的字串相應的函式轉成全大寫或全小寫後,也可以實現不區分大小寫的比較
if(strcasecmp(strtolower($userName),strtolower("admin")) == 0){
echo "使用者名稱存在";
}
//區分字串中字母的大小寫比較
switch(strcmp($password,"lampbrother")){
case 0:
echo "兩個字串相等
"; break;
case 1:
echo "第一個字串大於第二個字串
"; break;
case -1:
echo "第一個字串小於第二個字串
"; break;
}
?>
2.按自然排序進行字串比較
除了可以按照位元組位的字典順序進行比較外,PHP還提供了按照“自然排序”法對字串進行比較。所謂自然排序,是指按照人們的日常生活中的思維習慣進行排序,即將字串中的數字部分按照數字大小進行比較。例如按照位元組比較時“4”大於“33”,因為“4”大於“33”中的第一個字元,而按照自然排序法則“33”大於“4”。使用strnatcmp()函式按自然排序法比較兩個字串,該函式對大小寫敏感,其使用格式與strcmp()函式相似。
在下面的例子中,對一個數組中帶有數字的檔名,使用氣泡排序法通過兩種比較方法排序。程式碼如下所示:
複製程式碼 程式碼如下:
<?php
//定義一個包含數字值的陣列
$files = array("","","","");
function mySort($arr,$select = false){
for($i=0;$i<count($arr);$i++){
for($j;$j<count($arr)-1;$j++){
//如果第二個引數為ture則使用strcmp()函式比較大小
if($select){
//前後兩個值比較結果大於0則交換位置
if(strcmp($arr[$j],$arr[j+1])>0){
$tmp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $tmp;
}
//如果第二個引數為false則使用strnatcmp()函式比較大小
}else{
//如果比較結果大於0交換位置
if(strnatcmp($arr[$j],$arr[$j+1])>0){
$tmp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1]; = $tmp;
}
}
}
}
return $arr; //排序後的陣列
}
print_r(mySort($files,true)); //選擇按字典順序排序:
print_r(mySort($files,false)); //選擇按自然順序排序:
?>
在PHP中也提供了這個函式忽略大小寫的版本的函式strnatcasecmp()用法與strnatcmp()函式相同。