假设有下面一个二维数组:

$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'),);

现在要转换成一维数组,有两种情况:

一种是将指定列转换成一维数组,这在另一篇文章有总结:《PHP提取多维数组指定一列的方法大全》。

现在我们重点讲第二种情况,就是把所有的值都转换成一维数组,而且键值相同不会被覆盖,转换后的一维数组是这样的:

$result = array(100, 'a1', 101, 'a2', 102, 'a3', 103, 'a4', 104, 'a5');

主要有下面几个方法。

1 array_reduce函数法

用array_reduce()函数是较为快捷的方法:

$result = array_reduce($user, function ($result, $value) {    return array_merge($result, array_values($value));}, array())

因为array_merge函数会把相同字符串键名的数组覆盖合并,所以必须先用array_value取出值后再合并。

如果第二维是数字键名,如:

$user = array(    'a' => array(100, 'a1'),    'b' => array(101, 'a2'),    'c' => array(102, 'a3'),    'd' => array(103, 'a4'),    'e' => array(104, 'a5'),);

那么直接这样就可以了:

$result = array_reduce($user, 'array_merge', array())

2 array_walk_recursive函数法

用array_walk_recursive()函数就非常灵活,可以把任意维度的数组转换成一维数组。

$result = [];array_walk_recursive($user, function($value) use (&$result) {    array_push($result, $value);});

例如,下面这个多维数组:

$user4 = array(    'a' => array(100, 'a1'),    'b' => array(101, 'a2'),    'c' => array(        'd' => array(102, 'a3'),        'e' => array(103, 'a4'),    ),);

用这个方法后就变成:

$result = array(100, 'a1', 101, 'a2', 102, 'a3', 103, 'a4');

3 array_map函数法

用array_map和array_reduce函数的方法类似,如下:

$result = [];array_map(function ($value) use (&$result) {    $result = array_merge($result, array_values($value));}, $user);

只是需要多声明一个空的$result数组。

另外,也可以用array_walk的方法,和foreach循环的方法,原理和上面一样。

更多PHP相关知识,请访问PHP中文网!

更多相关文章

  1. php三个函数、两种选择防止sql注入
  2. 非常实用的PHP常用函数汇总-加密解密、字符串操作、文件操作、SQ
  3. PHP过滤数组中的0、null、false和''等空值
  4. PHP array_search 和 in_array 函数效率问题
  5. PHP将数组编码gbk和utf-8相互转换
  6. 匿名函数
  7. PHP 核心特性之匿名函数
  8. PHP数组具有的特性有哪些
  9. PHP中16个高危函数

随机推荐

  1. mysql 判断null 和 空字符串
  2. 通过Bash脚本语言逃避MYSQL命令行。
  3. 如何创建一个新表,该表根据名称获取其他表
  4. 错误1452:无法添加或更新子行:外键约束失败
  5. 分页查询-sql优化
  6. 防止左连接中的重复值
  7. MySql随笔part3 表操作
  8. MYSQL 导入53M数据报错
  9. 为什么我的变量在TCPDF中没有定义?
  10. 加入vs多个数据副本:性能