Ich habe jetzt schon eine Weile mit dem Kopf auf diesen einen geschlagen.
Ich habe dieses mehrdimensionale Array:
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
)
Und ich muss das bekommen:
Array
(
[0] => foo
[1] => bar
[2] => hello
[3] => world
[4] => love
[5] => stack
[6] => overflow
[7] => yep
[8] => man
)
Irgendwelche Ideen?
Alle anderen Lösungen, die ich gefunden habe, lösen mehrdimensionale Arrays mit unterschiedlichen Schlüsseln. Meine Arrays verwenden nur einfache numerische Tasten.
array_reduce($array, 'array_merge', array())
Beispiel:
$a = array(array(1, 2, 3), array(4, 5, 6));
$result = array_reduce($a, 'array_merge', array());
Ergebnis:
array[1, 2, 3, 4, 5, 6];
Der PHP array_merge
Docs Funktion kann Ihr Array abflachen:
$flat = call_user_func_array('array_merge', $array);
Falls das ursprüngliche Array eine höhere Tiefe als 2 Ebenen hat, hat die SPL in PHP eine RecursiveArrayIterator
, die Sie verwenden können, um sie zu reduzieren:
$flat = iterator_to_array(new RecursiveIteratorIterator(new RecursiveArrayIterator($array)), 0);
Siehe auch: Wie wird ein mehrdimensionales Array abgeflacht? .
Das ist wirklich alles was dazu gehört:
foreach($array as $subArray){
foreach($subArray as $val){
$newArray[] = $val;
}
}
Ab PHP 5.6 kann dies einfacher gemacht werden mit Argument Unpacking .
$flat = array_merge(...$array);
Ab PHP 5.3 scheint die kürzeste Lösung array_walk_recursive () mit der neuen Schließungssyntax zu sein:
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";
}
}
dabei ist $ a der Name Ihres Arrays. für Details
Ich hatte diesen Code verwendet, um dieselbe Art von Problem zu lösen. so kannst du das auch versuchen.
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;
}
Das wird machen
array_walk_recursive($array, function($a) use (&$return) { $return[] = $a; });
In PHP5.6 gibt es eine andere Möglichkeit, um dieses Problem zu lösen, die Funktionen zu kombinieren, array_shift()
, um das erste Element des ursprünglichen Arrays zu entfernen, array_pus()
, um Items ein neues Array hinzuzufügen, die wichtige Sache Ist der Splapt/Elipse-Operator von ...
, wird die Rückgabe von array_shitf()
wie ein Argument entpackt.
<?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);
Ausgabe:
Array
(
[0] => foo
[1] => bar
[2] => hello
[3] => world
[4] => love
[5] => stack
[6] => overflow
[7] => yep
[8] => man
[9] => wow
)
Die schnellste Lösung wäre die Verwendung dieser array library :
$flattened = Arr::flatten($yourArray);
was genau das Array erzeugt, das Sie wollen
$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'
)
)
);
ERGEBNIS (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"]