PHP提取多维数组指定一列的方法大全
PHP中对多维数组特定列的提取,是个很常用的功能,正因为如此,PHP在5.5.0版本之后,添加了一个专用的函数array_column()。当然,如果你的PHP版本低于5.5.0,就得用别的方法处理了。
例如,对于以下这个数组:
$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');
方法有以下几种。
1array_column函数法
用PHP内置的array_column() 函数是最简单的方法,限制是PHP版本必须是5.5.0及以上版本,方法:
$username=array_column($user,'username');
2array_walk函数法
array_walk()函数使用用户自定义函数对数组中的每个元素做回调处理,实现当前功能的方法:
$username=array(); array_walk($user,function($value,$key)use(&$username){ $username[]=$value['username']; });
3array_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$inputarray需要取出数组列的多维数组(或结果集) *@param$column_keystring需要返回值的列,它可以是索引数组的列索引,或者是关联数组的列的键。也可以是NULL,此时将返回整个数组 *@param$index_keystring作为返回数组的索引/键的列,它可以是该列的整数索引,或者字符串键值。 *@returnarray|null */ functionarray_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){ returnarray($d[$index_key]=>$d[$column_key]); } return$d[$column_key]; },$input); if($index_key!==null){ $tmp=array(); foreach($arras$ar){ $tmp[key($ar)]=current($ar); } $arr=$tmp; } return$arr; }
4foreach循环法
foreach循环相对上面的方法效率稍微低一些,但简单容易理解。
$username=array(); foreach($useras$value){ $username[]=$value['username']; }
5array_map变种
方法如下,意为把$user数组的每一项值的开头值移出,并获取移除的值作为新数组。注意此时新数组$username的键仍是原数组$user的键,如下。
$username=array_map('array_shift',$user);
注意:该功能会获取$user中的id列,而不是username列。
另外,如果需要获取二维数组每一项的开头列或结尾列,也可以这样做:
$username=array_map('reset',$user); $username=array_map('end',$user);
这三个变种方法作用比较局限,仅在获取第一列或最后一列的时候有用,在复杂的数组中就难以发挥作用了。
参考资料:
- php获取二维数组中某一列的值集合
- php快速的对二维数组某一列进行组装的方法