程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP 獲取二維數組中某個key的集合,二維數組key

PHP 獲取二維數組中某個key的集合,二維數組key

編輯:關於PHP編程

PHP 獲取二維數組中某個key的集合,二維數組key


本文為代碼分享,也是在工作中看到一些“大牛”的代碼,做做分享。

具體是這樣的,如下一個二維數組,是從庫中讀取出來的。

代碼清單:

 

[php] view plain copy    在CODE上查看代碼片派生到我的代碼片
  1. $user = array(  
  2.     0 => array(  
  3.         'id'    => 1,  
  4.         'name'  => '張三',  
  5.         'email' => '[email protected]',  
  6.     ),  
  7.     1 => array(  
  8.         'id'    => 2,  
  9.         'name'  => '李四',  
  10.         'email' => '[email protected]',  
  11.     ),  
  12.     2 => array(  
  13.         'id'    => 5,  
  14.         'name'  => '王五',  
  15.         'email' => '[email protected]',  
  16.     ),  
  17.     ......  
  18. );  


上面的數組格式,主要大家玩過 PHP+MYSQL,就肯定非常熟悉了。

 

那麼,現在有這樣的兩個需求:

1)獲取索引"id"的集合,並且保存為一個一位數組,即得到 array(1,2,5)

不知道各位朋友會怎麼寫呢?

如果是以前我的寫法就是直接 foreach,然後 array_push 一個個的往一個數組變量裡塞。這樣也能實現。但這樣的寫法很影響性能,因為使用 PHP 原生的函數肯定比循環效率高。

代碼清單:

 

[php] view plain copy    在CODE上查看代碼片派生到我的代碼片
  1. $ids = array();  
  2. $ids = array_map('array_shift', $user);  


如上代碼就可以得到我們想要的結果了,關於函數的使用想看手冊。

 

其實這裡面還有一種方案,使用 array_column 函數,不過此函數需要 PHP 版本要求,(PHP 5 >= 5.5.0)

代碼清單:

 

[php] view plain copy    在CODE上查看代碼片派生到我的代碼片
  1. $ids = array();  
  2. $ids = array_column($user, 'id');  

 

 

這樣的話,效率肯定會更高了。


2)獲取索引"name"的集合,並且保存為一個一位數組,即得到 array('張三','李四',‘王五’)

按照,我以往的寫法,還是一樣的foreach,然後 array_push 一個個的往一個數組變量裡塞。請看高效率的代碼清單。

代碼清單:

 

[php] view plain copy    在CODE上查看代碼片派生到我的代碼片
  1. $names = array();  
  2. $names = array_reduce($user, create_function('$v,$w', '$v[$w["id"]]=$w["name"];return $v;'));  


得到結果:

 

 

[php] view plain copy    在CODE上查看代碼片派生到我的代碼片
  1. array(  
  2.     1 => '張三',  
  3.     2 => '李四',  
  4.     5 => '王五',  
  5. );  

 

經常 foreach 的童鞋,趕快更正吧!

本文來自CSDN,轉載請注明出處!http://blog.csdn.net/liruxing1715/article/details/22925575

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved