PHP基于array_unique實現(xiàn)二維數(shù)組去重
array_unique函數(shù)就是可以處重的,它具備了這個功能了,下面我們一來看一個關于PHP使用array_unique對二維數(shù)組去重處理例子。
php 5.2.9 版本增加了array_unique對多維數(shù)組的支持,在處理多維數(shù)組是需要設置sort_flags參數(shù)
一維數(shù)組的重復項:
使用array_unique函數(shù)即可,使用實例如下:
代碼如下
<?php
$aa = array("apple", "banana", "pear", "apple", "wail", "watermalon");
$bb = array_unique($aa);
print_r($bb);
?>
結果如下:
Array ( [0] => apple [1] => banana [2] => pear [4] => wail [5] => watermalon )
二維數(shù)組去重項
代碼如下
例如:
$result = array(
0=>array('a'=>1,'b'=>'Hello'),
1=>array('a'=>1,'b'=>'other'),
2=>array('a'=>1,'b'=>'other'),
);
處理成
$result = array(
0=>array('a'=>1,'b'=>'Hello'),
1=>array('a'=>1,'b'=>'other')
);
使用方法
array_unique($result, SORT_REGULAR);
二維數(shù)組的重復項:
對于二維數(shù)組咱們分兩種情況討論,一種是因為某一鍵名的值不能重復,刪除重復項;另一種因為內部的一維數(shù)組不能完全相同,而刪除重復項,下面舉例說明:
㈠因為某一鍵名的值不能重復,刪除重復項
PHP代碼如下
<?php
function assoc_unique($arr, $key) {
$tmp_arr = array();
foreach ($arr as $k => $v) {
if (in_array($v[$key], $tmp_arr)) {//搜索$v[$key]是否在$tmp_arr數(shù)組中存在,若存在返回true
unset($arr[$k]);
} else {
$tmp_arr[] = $v[$key];
}
}
sort($arr); //sort函數(shù)對數(shù)組進行排序
return $arr;
}
$aa = array(
array('id' => 123, 'name' => '張三'),
array('id' => 123, 'name' => '李四'),
array('id' => 124, 'name' => '王五'),
array('id' => 125, 'name' => '趙六'),
array('id' => 126, 'name' => '趙六')
);
$key = 'id';
assoc_unique(&$aa, $key);
print_r($aa);
?>
顯示結果為:
Array ( [0] => Array ( [id] => 123 [name] => 張三 ) [1] => Array ( [id] => 124 [name] => 王五 ) [2] => Array ( [id] => 125 [name] => 趙六 ) [3] => Array ( [id] => 126 [name] => 趙六 ) )
因內部的一維數(shù)組不能完全相同,而刪除重復項
代碼如下
<?php
function array_unique_fb($array2D) {
foreach ($array2D as $v) {
$v = join(",", $v); //降維,也可以用implode,將一維數(shù)組轉換為用逗號連接的字符串
$temp[] = $v;
}
$temp = array_unique($temp);//去掉重復的字符串,也就是重復的一維數(shù)組
foreach ($temp as $k => $v) {
$temp[$k] = explode(",", $v);//再將拆開的數(shù)組重新組裝
}
return $temp;
}
$aa = array(
array('id' => 123, 'name' => '張三'),
array('id' => 123, 'name' => '李四'),
array('id' => 124, 'name' => '王五'),
array('id' => 123, 'name' => '李四'),
array('id' => 126, 'name' => '趙六')
);
$bb = array_unique_fb($aa);
print_r($bb)
?>
顯示結果:
Array ( [0] => Array ( [0] => 123 [1] => 張三 ) [1] => Array ( [0] => 123 [1] => 李四 ) [2] => Array ( [0] => 124 [1] => 王五 ) [4] => Array ( [0] => 126 [1] => 趙六 ) )
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
通過緩存數(shù)據(jù)庫結果提高PHP性能的原理介紹
眾所周知,緩存數(shù)據(jù)庫查詢的結果可以顯著縮短腳本執(zhí)行時間,并最大限度地減少數(shù)據(jù)庫服務器上的負載。如果要處理的數(shù)據(jù)基本上是靜態(tài)的,則該技術將非常有效。這是因為對遠程數(shù)據(jù)庫的許多數(shù)據(jù)請求最終可以從本地緩存得到滿足,從而不必連接到數(shù)據(jù)庫、執(zhí)行查詢以及獲取結果2012-09-09

