本文实例讲述了PHP实现提取多维数组指定一列的方法。分享给大家供大家参考,具体如下:
PHP中对多维数组特定列的提取,是个很常用的功能,正因为如此,PHP在5.5.0版本之后,添加了一个专用的函数array_column()。当然,如果你的PHP版本低于5.5.0,就得用别的方法处理了。
相关学习推荐:php编程(视频)
例如,对于以下这个数组:
复制$user = array(0=> array(id=>100,username=>a1),1=> array(id=>101,username=>a2),2=> array(id=>102,username=>a3),3=> array(id=>103,username=>a4),4=> array(id=>104,username=>a5),);
我们要提取其中的 usename 列,变成:
复制$username = array(a1,a2,a3,a4,a5);
方法有以下几种。
1 array_column函数法
用PHP内置的 array_column() 函数是最简单的方法,限制是PHP版本必须是5.5.0及以上版本,方法:
复制$username = array_column($user,username);
2 array_walk函数法
array_walk()函数使用用户自定义函数对数组中的每个元素做回调处理,实现当前功能的方法:
复制$username = array();
array_walk($user,function($value, $key)use(&$username){
$username[]= $value[username];});
3 array_map函数法
array_map()函数和array_walk() 作用类似,将回调函数作用到给定数组的单元上。
复制$username = array();
array_map(function($value)use(&$username){
$username[]= $value[username];}, $user);
实际使用时,我们可以用array_map()写出和PHP内置array_column()一样功能的函数:
复制/**
* 获取二维数组指定的一列,并以一维数组格式返回
* 作用和PHP5.5.0中的array_column()函数一样
* @param $input array 需要取出数组列的多维数组(或结果集)
* @param $column_key string 需要返回值的列,它可以是索引数组的列索引,或者是关联数组的列的键。 也可以是NULL,此时将返回整个数组
* @param $index_key string 作为返回数组的索引/键的列,它可以是该列的整数索引,或者字符串键值。
* @return array|null
*/function array_column($input, $column_key, $index_key =null){
$arr = array_map(function($d)use($column_key, $index_key){if(!isset($d[$column_key])){returnnull;}if($index_key !==null){return array($d[$index_key]=> $d[$column_key]);}return $d[$column_key];}, $input);if($index_key !==null){
$tmp = array();foreach($arr as $ar){
$tmp[key($ar)]= current($ar);}
$arr = $tmp;}return $arr;}
4 foreach循环法
foreach循环相对上面的方法效率稍微低一些,但简单容易理解。
复制$username = array();foreach($user as $value){
$username[]= $value[username];}
5 array_map变种
方法如下,意为把$user数组的每一项值的开头值移出,并获取移除的值作为新数组。注意此时新数组$username的键仍是原数组$user的键,如下。
复制$username = array_map(array_shift, $user);
注意:该功能会获取$user中的 id 列,而不是 username 列。
另外,如果需要获取二维数组每一项的开头列或结尾列,也可以这样做:
复制$username = array_map(reset, $user);
$username = array_map(end, $user);
这三个变种方法作用比较局限,仅在获取第一列或最后一列的时候有用,在复杂的数组中就难以发挥作用了。
相关推荐:编程视频课程