php 數(shù)組過濾函數(shù) array_filter與array_unique
來源:程序員人生 發(fā)布時間:2014-03-07 14:19:57 閱讀次數(shù):4422次
在php中我給大家介紹兩個比較常用的數(shù)組過濾函數(shù)array_filter與array_unique了,一個是過濾數(shù)組空值,一個是過濾數(shù)組重復值,我們現(xiàn)在一起來看看。
語法:array_filter(array,function)
array 必需,規(guī)定輸入的數(shù)組,function 自定義函數(shù)的名稱,為空時過濾掉所有值為flase的元素,代碼如下:
- <?php
-
- function odd($var) {
- return($var & 1);
- }
-
- function even($var) {
- return(!($var & 1));
- }
-
- $array1 = array("a"=>1, "b"=>2, "c"=>3, "d"=>4, "e"=>5);
- $array2 = array(6, 7, 8, 9, 10, 11, 12);
-
- echo "Odd :n";
- print_r(array_filter($array1, "odd"));
- echo "Even:n";
- print_r(array_filter($array2, "even"));
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
過濾掉PHP數(shù)組中的重復值,去除一個數(shù)組中的重復值,可以使用foreach方法,也可以使用array_unique方法,下面的代碼兩種方法都使用了,代碼如下:
- <?php
- $arrF = array();
- $arrS = array();
- $intTotal = 100;
- $intRand = 10;
- for($i=0; $i < $intTotal; $i++)
- {
- $arrF[] = rand(1, $intRand);
- $arrS[] = rand(1, $intRand);
- }
- $arrT = array_merge($arrF, $arrS);
- $arrRF = array();
- $intStart = time();
- foreach($arrT as $v)
- {
- if(in_array($v, $arrRF))
- {
- continue;
- }
- else
- {
- $arrRF[] = $v;
- }
- }
- $intEnd = time();
- $intTime = $intEnd-$intStart;
- echo "With Continue,Spend time:$intTime<br/>";
- $intStart1 = time();
- $arrRS = array_unique($arrT);
- $intEnd2 = time();
- $intTime2 = $intEnd2-$intStart1;
- echo "With array_unique function,Spend time:($intTime2)";
- echo "<pre>";
- print_r($arrT);
- print_r($arrRF);
- print_r($arrRS);
- echo "</pre>";
- ?>
在$intTotal比較小的情況下,比如說1000以內,$intRand的取值基本不影響結果,兩者執(zhí)行的時間都差不多。
測試$intTotal 大于10000時,$intRand取值100時,使用array_unique的效率要高于foreach循環(huán)判斷,$intRand=10,兩者執(zhí)行時間一致。
因此,可以得出結論,當數(shù)組容量不大,大概在1000以內時,使用兩者的執(zhí)行效率差不多,當數(shù)組容量比較大時(具體應該到什么值,我沒有詳細測試,感興趣的可以確定一下這個值),隨著$intRand的逐漸增大,array_unique的表現(xiàn)更好,我不使用$intTotal/$intRand這個比值,是因為,感覺并不是成比例變化,但是基本會遵循比值越大,array_unique表現(xiàn)越好。
綜上所述,在過濾數(shù)組重復值的時候,建議使用array_unuique,數(shù)組不大的時候兩者效率等同,而array_unique使用當然讓你的代碼一下子減了好幾行,數(shù)組容量過大時,函數(shù)的表現(xiàn)更好
二維數(shù)組去重復項函數(shù)
PHP數(shù)組去除重復項 有個內置函數(shù)array_unique (),但是php的 array_unique函數(shù)只適用于一維數(shù)組,對多維數(shù)組并不適用,以下提供一個二維數(shù)組 的 array_unique函數(shù),代碼如下:
- function unique_arr($array2D,$stkeep=false,$ndformat=true)
- {
-
- if($stkeep) $stArr = array_keys($array2D);
-
- if($ndformat) $ndArr = array_keys(end($array2D));
-
- foreach ($array2D as $v){
- $v = join(",",$v);
- $temp[] = $v;
- }
-
- $temp = array_unique($temp);
-
- foreach ($temp as $k => $v)
- {
- if($stkeep) $k = $stArr[$k];
- if($ndformat)
- {
- $tempArr = explode(",",$v);
- foreach($tempArr as $ndkey => $ndval) $output[$k][$ndArr[$ndkey]] = $ndval;
- }
- else $output[$k] = explode(",",$v);
- }
- return $output;
- }
- 測試
- $array2D = array('first'=>array('title'=>'1111','date'=>'2222'),'second'=>array('title'=>'1111','date'=>'2222'),'third'=>array('title'=>'2222','date'=>'3333'));
-
- print_r($array2D);
- print_r(unique_arr($array2D,true));
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈