<?php
$array = [
[
'id' => 1,
'parentId' => ""
],
[
'id' => 2,
'parentId' => 1
],
[
'id' => 3,
'parentId' => 2
]
];
$entriesById = array_column($array, null, 'id');
$entriesWithAncestors = array_reduce(
$entriesById,
static function (array $result, array $entry) use ($entriesById): array {
$result[$entry['id']] = $entry + ['ancestors' => []];
$parentId = $entry['parentId'];
while (isset($result[$parentId])) {
$result[$entry['id']]['ancestors'][] = $result[$parentId];
$parentId = $entriesById[$parentId]['parentId'] ?? null;
}
return $result;
}, []
);
print_r($entriesWithAncestors);
- Output for 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.33, 8.2.0 - 8.2.29, 8.3.0 - 8.3.25, 8.4.1 - 8.4.12
- Array
(
[1] => Array
(
[id] => 1
[parentId] =>
[ancestors] => Array
(
)
)
[2] => Array
(
[id] => 2
[parentId] => 1
[ancestors] => Array
(
[0] => Array
(
[id] => 1
[parentId] =>
[ancestors] => Array
(
)
)
)
)
[3] => Array
(
[id] => 3
[parentId] => 2
[ancestors] => Array
(
[0] => Array
(
[id] => 2
[parentId] => 1
[ancestors] => Array
(
[0] => Array
(
[id] => 1
[parentId] =>
[ancestors] => Array
(
)
)
)
)
[1] => Array
(
[id] => 1
[parentId] =>
[ancestors] => Array
(
)
)
)
)
)
preferences:
137.71 ms | 413 KiB | 5 Q