我已经在这个问题上敲了一会儿。
我有这个多维数组:
Array
(
[0] => Array
(
[0] => foo
[1] => bar
[2] => hello
)
[1] => Array
(
[0] => world
[1] => love
)
[2] => Array
(
[0] => stack
[1] => overflow
[2] => yep
[3] => man
)
我需要得到这个:
Array
(
[0] => foo
[1] => bar
[2] => hello
[3] => world
[4] => love
[5] => stack
[6] => overflow
[7] => yep
[8] => man
)
有什么想法吗?
我发现的所有其他解决方案都解决了具有不同键的多维数组。我的数组只使用简单的数字键。
答案 0 :(得分:73)
array_reduce($array, 'array_merge', array())
示例:
$a = array(array(1, 2, 3), array(4, 5, 6));
$result = array_reduce($a, 'array_merge', array());
结果:
array[1, 2, 3, 4, 5, 6];
答案 1 :(得分:38)
PHP array_merge
Docs函数可以展平您的数组:
$flat = call_user_func_array('array_merge', $array);
如果原始数组的深度高于2个级别,则PHP中的SPL可以使用RecursiveArrayIterator
来展平它:
$flat = iterator_to_array(new RecursiveIteratorIterator(new RecursiveArrayIterator($array)), 0);
答案 2 :(得分:9)
这就是它的全部内容:
foreach($array as $subArray){
foreach($subArray as $val){
$newArray[] = $val;
}
}
答案 3 :(得分:6)
As of PHP 5.6这可以通过argument unpacking更简单地完成。
$flat = array_merge(...$array);
答案 4 :(得分:3)
foreach ($a as $v1) {
foreach ($v1 as $v2) {
echo "$v2\n";
}
}
其中$ a是您的数组名称。 for details
答案 5 :(得分:3)
从PHP 5.3开始,最短的解决方案似乎是带有新闭包语法的array_walk_recursive():
function flatten(array $array) {
$return = array();
array_walk_recursive($array, function($a) use (&$return) { $return[] = $a; });
return $return;
}
答案 6 :(得分:1)
在PHP5.6中还有其他解决这个问题的方法,结合函数array_shift()
删除原始数组的第一个元素,array_pus()
添加一个新数组的项,重要的是在...
splapt / elipse运算符中,它将像参数一样解包array_shitf()
的返回值。
<?php
$arr = [
['foo', 'bar', 'hello'],
['world', 'love'],
['stack', 'overflow', 'yep', 'man', 'wow']
];
$new = [];
while($item = array_shift($arr)){
array_push($new, ...$item);
}
print_r($new);
输出:
Array
(
[0] => foo
[1] => bar
[2] => hello
[3] => world
[4] => love
[5] => stack
[6] => overflow
[7] => yep
[8] => man
[9] => wow
)
答案 7 :(得分:1)
我曾使用此代码来解决相同类型的问题。所以你也可以试试这个。
function array_flatten($array) {
if (!is_array($array))
{
return FALSE;
}
$result = array();
foreach ($array as $key => $value)
{
if (is_array($value))
{
$result = array_merge($result, array_flatten($value));
}
else {
$result[$key] = $value;
}
}
return $result;
}
答案 8 :(得分:1)
这将使
array_walk_recursive($array, function($a) use (&$return) { $return[] = $a; });
答案 9 :(得分:0)
$blocked_dates = array(
'2014' => Array
(
'8' => Array
(
'3' => '1',
'4' => '1',
'6' => '1',
'10' => '1',
'15' => '1',
'25' => '1'
)
),
'2015' => Array
(
'9' => Array
(
'3' => '1',
'4' => '1',
'6' => '1',
'10' => '1',
'15' => '1',
'25' => '1'
)
)
);
结果(一维阵列):
$unavailable_dates = array();
foreach ($blocked_dates as $year=>$months) {
foreach ($months as $month => $days) {
foreach ($days as $day => $value) {
array_push($unavailable_dates,"$year-$month-$day");
}
}
}
$unavailable_dates = json_encode($unavailable_dates);
print_r($unavailable_dates);
OUTPUT : ["2014-8-3","2014-8-4","2014-8-6","2014-8-10","2014-8-15","2014-8-25","2015-9-3","2015-9-4","2015-9-6","2015-9-10","2015-9-15","2015-9-25"]
答案 10 :(得分:0)