一、數(shù)組操作的基本函數(shù)
數(shù)組的鍵名和值
array_values($arr);? 獲得數(shù)組的值
array_keys($arr);? 獲得數(shù)組的鍵名
array_flip($arr);? 數(shù)組中的值與鍵名互換(如果有重復前面的會被后面的覆蓋)
in_array("apple",$arr);? 在數(shù)組中檢索apple ? //存在返回1奢入,不存在返回空
array_search("apple",$arr);? 在數(shù)組中檢索apple 段标,如果存在返回鍵名 ? ? //存在返回鍵名驹愚,不存在返回空
array_key_exists("apple",$arr);? 檢索給定的鍵名是否存在數(shù)組中? ? //存在返回1磷瘤,不存在返回空
isset($arr[apple]):? 檢索給定的鍵名是否存在數(shù)組中? ? ? ? ? ? //存在返回1,不存在返回空
數(shù)組的內部指針
current($arr);? 返回數(shù)組中的當前單元 ? ?//返回當前單元值
pos($arr);? 返回數(shù)組中的當前單元 ? ? ?//同current盗胀,是current的別名
key($arr);? 返回數(shù)組中當前單元的鍵名
prev($arr);? 將數(shù)組中的內部指針倒回一位
next($arr);? 將數(shù)組中的內部指針向前移動一位
end($arr);? 將數(shù)組中的內部指針指向最后一個單元
reset($arr;? 將數(shù)組中的內部指針指向第一個單元
each($arr);? 將返回數(shù)組當前元素的一個鍵名/值的構造數(shù)組官边,并使數(shù)組指針向前移動一位
/*代碼示例
$a1=array("a"=>"red","b"=>"green","c"=>"blue","d"=>"yellow");
print_r(each($a1));
輸出結果:
Array ( [1] => red [value] => red [0] => a [key] => a )
*/
list函數(shù)用于在一次操作中給一組變量賦值
/*
該函數(shù)只用于數(shù)字索引的數(shù)組沸手,且假定數(shù)字索引從 0 開始
$my_array = array("Dog","Cat","Horse");list($a, $b, $c)= $my_array;echo "I have several animals, a $a, a $b and a $c.";
輸出結果:
I have several animals, a Dog, a Cat and a Horse.
*/
數(shù)組和變量之間的轉換
extract($arr);用于把數(shù)組中的元素轉換成變量導入到當前文件中外遇,鍵名當作變量名,值作為變量值
注:(第二個參數(shù)很重要契吉,可以看手冊使用)使用方法 echo $a;
compact(var1,var2,var3);用給定的變量名創(chuàng)建一個數(shù)組
二跳仿、數(shù)組的分段和填充
數(shù)組的分段
array_slice($arr,0,3);? 可以將數(shù)組中的一段取出,此函數(shù)忽略鍵名
array_splice($arr,0,3捐晶,array("black","maroon"));? 可以將數(shù)組中的一段取出菲语,與上個函數(shù)不同在于返回的序列從原數(shù)組中刪除
分割多個數(shù)組
array_chunk($arr,size,TRUE);? 可以將一個數(shù)組分割成多個,TRUE為保留原數(shù)組的鍵名
數(shù)組的填充
array_pad($arr,5,'x');? 將一個數(shù)組填補到制定長度
三惑灵、數(shù)組與棧
array_push($arr,"apple","pear");? 將一個或多個元素壓入數(shù)組棧的末尾(入棧)山上,返回入棧元素的個數(shù)
array_pop($arr);? 將數(shù)組棧的最后一個元素彈出(出棧)
四、數(shù)組與列隊
array_shift($arr);數(shù)組中的第一個元素移出并作為結果返回(數(shù)組長度減1英支,其他元素向前移動一位佩憾,數(shù)字鍵名改為從零技術,文字鍵名不變)
array_unshift($arr,"a",array(1,2));在數(shù)組的開頭插入一個或多個元素
五潭辈、回調函數(shù)
array_walk($arr,'function','words');? 使用用戶函數(shù)對數(shù)組中的每個成員進行處理(第三個參數(shù)傳遞給回調函數(shù)function)
array_mpa("function",$arr1,$arr2);? 可以處理多個數(shù)組(當使用兩個或更多數(shù)組時鸯屿,他們的長度應該相同)
array_filter($arr,"function");? 使用回調函數(shù)過濾數(shù)組中的每個元素澈吨,如果回調函數(shù)為TRUE把敢,數(shù)組的當前元素會被包含在返回的結果數(shù)組中,數(shù)組的鍵名保留不變
array_reduce($arr,"function","*");? 轉化為單值函數(shù)(*為數(shù)組的第一個值)
六谅辣、數(shù)組的排序
通過元素值對數(shù)組排序
sort($arr);? 由小到大的順序排序
rsort($arr);? 由大到小的順序排序(第二個參數(shù)為按什么方式排序)忽略鍵名的數(shù)組排序
usort($arr,"function");? 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序(function中有兩個參數(shù)修赞,0表示相等,正數(shù)表示第一個大于第二個桑阶,負數(shù)表示第一個小于第二個)忽略鍵名的數(shù)組排序
asort($arr);? 由小到大的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
arsort($arr);? 由大到小的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
uasort($arr,"function");? 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序(function中有兩個參數(shù)柏副,0表示相等,正數(shù)表示第一個大于第二個蚣录,負數(shù)表示第一個小于第二個)保留鍵名的數(shù)組排序
通過鍵名對數(shù)組排序
ksort($arr);? 按照鍵名正序排序
krsort($arr);? 按照鍵名逆序排序
uksort($arr,"function");? 使用用戶自定義的比較函數(shù)對數(shù)組中的鍵名進行排序(function中有兩個參數(shù)割择,0表示相等,正數(shù)表示第一個大于第二個萎河,負數(shù)表示第一個小于第二個)
自然排序法排序
natsort($arr);? 自然排序(忽略鍵名)
natcasesort($arr);? 自然排序(忽略大小寫荔泳,忽略鍵名)
七、數(shù)組的計算
數(shù)組元素的求和
array_sum($arr);? 對數(shù)組內部的所有元素做求和運算
數(shù)組的合并
array_merge($arr1,$arr2);? 合并兩個或多個數(shù)組(相同的字符串鍵名虐杯,后面的覆蓋前面的玛歌,相同的數(shù)字鍵名,后面的不會做覆蓋操作擎椰,而是附加到后面)
“+”$arr1+$arr2;? 對于相同的鍵名只保留后一個
array_merge_recursive($arr1,$arr2);?? 遞歸合并操作支子,如果數(shù)組中有相同的字符串鍵名,這些值將被合并到一個數(shù)組中去达舒。如果一個值本身是一個數(shù)組值朋,將按照相應的鍵名把它合并為另一個數(shù)組叹侄。當數(shù)組 具有相同的數(shù)組鍵名時,后一個值將不會覆蓋原來的值吞歼,而是附加到后面
數(shù)組的差集
array_diff($arr1,$arr2);? 返回差集結果數(shù)組
array_diff_assoc($arr1,$arr2,$arr3);? 返回差集結果數(shù)組圈膏,鍵名也做比較
數(shù)組的交集
array_intersect($arr1,$arr2);? 返回交集結果數(shù)組
array_intersect_assoc($arr1,$arr2);? 返回交集結果數(shù)組,鍵名也做比較
八篙骡、其他的數(shù)組函數(shù)
range(0,12);? 創(chuàng)建一個包含指定范圍單元的數(shù)組
array_unique($arr);? 移除數(shù)組中重復的值稽坤,新的數(shù)組中會保留原始的鍵名
array_reverse($arr,TRUE);? 返回一個單元順序與原數(shù)組相反的數(shù)組,如果第二個參數(shù)為TRUE保留原來的鍵名
//srand((float)microtime()*10000000);?? 隨機種子觸發(fā)器
array_rand($arr,2);? 從數(shù)組中隨機取出一個或 多個元素
shuffle($arr);? 將數(shù)組的順序打亂
文章來源鏈接? http://www.cnblogs.com/zhengfengyun/p/5360721.html