私はしばらくの間これに頭を叩いてきました。
私はこの多次元配列を持っています:
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
)
何か案は?
私が見つけた他のすべてのソリューションは、異なるキーで多次元配列を解決します。私の配列は単純な数字キーのみを使用しています。
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];
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);
参照: 多次元配列をフラット化する方法? 。
これが本当にすべてです。
foreach($array as $subArray){
foreach($subArray as $val){
$newArray[] = $val;
}
}
PHP 5.6 の時点で、これは argument unpacking でより簡単に行うことができます。
$flat = array_merge(...$array);
PHP 5.3現在、最短の解決策は新しいクロージャ構文を使用したarray_walk_recursive()のようです。
function flatten(array $array) {
$return = array();
array_walk_recursive($array, function($a) use (&$return) { $return[] = $a; });
return $return;
}
foreach ($a as $v1) {
foreach ($v1 as $v2) {
echo "$v2\n";
}
}
$ aは配列名です。 詳細
私はこのコードを使用して同じタイプの問題を解決しました。これも試してみることができます。
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;
}
これにより
array_walk_recursive($array, function($a) use (&$return) { $return[] = $a; });
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
)
_
$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'
)
)
);
RESULT(ONE DIMENSIONAL ARRAY):
$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"]