2010-04-29 4 views
1

Существует множество примеров использования RecursiveIterator для сглаживания древовидной структуры .. но как насчет его использования, чтобы взорвать древовидную структуру?A RecursiveParentChildIterator - как рекурсивныйDirectoryIterator

Есть элегантный способ использовать это, или какая-либо другая библиотека SPL рекурсивно построить дерево (читайте: превратить плоский массив в массив произвольной глубины) дала таблицу, как это:

SELECT id, parent_id, name FROM my_tree 

EDIT: Вы знаете, как это сделать с помощью Каталогов?

$it = new RecursiveDirectoryIterator("/var/www/images"); 
foreach(new RecursiveIteratorIterator($it) as $file) { 
    echo $file . PHP_EOL; 
} 

.. Что делать, если вы могли бы сделать что-то вроде этого:

$it = new RecursiveParentChildIterator($result_array); 
foreach(new RecursiveIteratorIterator($it) as $group) { 
    echo $group->name . PHP_EOL; 
    // this would contain all of the children of this group, recursively 
    $children = $group->getChildren(); 
} 

: END EDIT

+0

Возможно, вы захотите указать вход/выход exa mple – Gordon

+0

@ Gordon Действительно, i/o может быть чем угодно (mysqli result => ассоциативный массив/некоторый объект .. что угодно) - то, что я действительно ищу, - это элегантный способ, используя SPL, а не какой-то домашний материал, чтобы преобразуйте результаты вышеуказанного запроса в объект или массив, который понимает, например, что «строка 3 является дочерним элементом строки 7, потому что (parent_id в строке 3) == (id в строке 7)». –

+1

@ Stephen причина, по которой я предложил дать пример, объясняется тем, что дерево терминов не слишком хорошо известно среди толпы PHP, но если вы приведете пример, люди могут придумать решение, даже если они не знают они просто работали с деревом. – Gordon

ответ

2

Хотя не SPL, но вы можете использовать ссылки (&) построить дерево с родным PHP:

// untested 
$nodeList = array(); 
$tree  = array(); 
foreach ($result as $row) { 
    $nodeList[$row['id']] = array_merge($row, array('children' => array())); 
} 
foreach ($nodeList as $nodeId => &$node) { 
    if (!$node['parent_id'] || !array_key_exists($node['parent_id'], $nodeList)) { 
     $tree[] = &$node; 
    } else { 
     $nodeList[$node['parent_id']]['children'][] = &$node; 
    } 
} 
unset($node); 
unset($nodeList); 
+0

Это, кажется, лучшее решение, с которым я столкнулся до сих пор (они используют один и тот же процесс здесь: http://bit.ly/4IyIBR). Я ценю его скрытый способ избежать рекурсии - процесс, который я нахожу, лучше всего зарезервирован для своего рода шаблона многократного использования, например, предоставленного в библиотеке SPL. –