本例對二維數組中某個指定鍵名進行去重,發現網上大多使用array_unique或是foreach遍歷等方式去重,效果不佳且較為繁瑣。
本文以二維數組去重為引,介紹array_column函數的三種用法。
以下是本人常用的去重方法:
以指定字段為索引,自然會把索引字段中重復的值覆蓋掉, 然后在去除關聯索引就可以了
//array_column第一種用法,以指定字段為索引
$data= array( array('id' => 123, 'name' => '張三'), array('id' => 123, 'name' => '李四'), array('id' => 124, 'name' => '王五'), array('id' => 125, 'name' => '趙六'), array('id' => 126, 'name' => '趙六') );
上述是一個二維數組,我們需要把相同 id 的記錄去掉,即一個ID只保留一條記錄;只使用第三個參數試驗,
$data = array_column($data, NULL, 'id'); //以ID為索引 $data = array_values($data); //去除關聯索引
OK,去重完成,此時$data數據如下:五條記錄變為四條
$data= array( array('id' => 123, 'name' => '張三'), array('id' => 124, 'name' => '王五'), array('id' => 125, 'name' => '趙六'), array('id' => 126, 'name' => '趙六') );
另外,講下第二個參數,代表需要保留的(單)列,下面我們將使用第二個參數,而不使用第三個參數。
array_column第二種用法:
$data = array_column($data, 'name');
此時二維數組只保留 name 字段,id字段被刪除,數據如下:
$data= array( array('name' => '張三'), array('name' => '李四'), array('name' => '王五'), array('name' => '趙六'), array('name' => '趙六') );
array_column的第三種用法,
三個參數全部使用: 用來構造 'id' => 'name' 形式的數據
$data = array_column($data, 'name', 'id');
此時數據如下:此時ID重復的也被剔除了,前面的被覆蓋。
$data = array( '123' => '李四', '124' => '王五', '125' => '趙六', '126' => '趙六' );
see you ~