首页 > 作文

PHP实现二维数组(或多维数组)转换成一维数组的常见方法总结

更新时间:2023-04-08 05:00:19 阅读: 评论:0

本文实例总结了php实现二维数组(或多维数组)转换成一维数组的常见方法。分享给大家供大家参考,具体如下:

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

$ur李商隐 = array(  '0' => array('id' => 100, 'urname' => 'a1'),  '1' => array('id' => 101, 'urname' => 'a2'),  '2' => array('id' => 102, 'urname' => 'a3'),  '3' => array('id' => 103, 'urname' => 'a4'),  '4' => array('id' => 104, 'urname' => 'a5'),);

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

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

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

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

主要有下面几个方法。

1 array_reduce函数法

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

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

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

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

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

那么直接这样就可以了:

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

2 array_walk_recursive函数法

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

$result = [];array_walk_recursive($ur, fun全国医学院校排名ction($value) 婚庆公司策划方案u (&$result) {  array_push($result, $value);});

例如,下面这个多虚拟内存不足维数组:

$ur4 = array(  'cr是什么元素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) u (&$result) {  $result = array_merge($result, array_values($value));}, $ur);

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

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

本文发布于:2023-04-08 05:00:17,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/a295ea1ed607a1c7acf4def70fbc492c.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP实现二维数组(或多维数组)转换成一维数组的常见方法总结.doc

本文 PDF 下载地址:PHP实现二维数组(或多维数组)转换成一维数组的常见方法总结.pdf

标签:数组   函数   方法   转换成
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图