Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
0 / 0 / 0
Регистрация: 18.07.2011
Сообщений: 13

Сформировать иерархическое дерево с произвольным уровнем вложения

21.07.2014, 22:31. Показов 2501. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!
Помогите, пожалуйста, сформировать иерархическое дерево с произвольным уровнем вложения.
Есть таблица
PHP
1
2
3
4
5
id  | parent_id | name
0        0            name0
1        0            name1
2        1            name2
3        2            name3
Нужно пролучить массив вида:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
data [
  [0] =>   [  
    id =>       0,
    name =>       'name0',
    childrens => []
] ,
[1] =>   [
    id =>        1
    name =>      'name1',
    childrens => [
          id => 2,
          name => name2,
          childrens => [
             id =>       3,
             name =>       'name3',
             childrens => []
          ]
]
 
]
Заранее спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.07.2014, 22:31
Ответы с готовыми решениями:

Вывод директорий с указанным уровнем вложения
Вывести в файл список всех директорий и ее поддиректорий с указанным уровнем вложения, зарегистрированной в заданной. Указание - можно...

Иерархическое дерево и MySQL
Как сделать Иерархическое дерево в windows forms что бы папки в нем соответствовали таблицам в базе данных а "файлы" в этик...

TTreeView-иерархическое дерево
Вот есть дерево. Оно заполнено различными названиями. И при клике на кнопку программа должна понять какой элемент дерева выбран и выполнить...

4
> /dev/null
 Аватар для Блеф
286 / 119 / 86
Регистрация: 14.05.2014
Сообщений: 767
21.07.2014, 22:46
kinki, что у вас не получаеться? Как уже пробывали?
Иначе вас суда
0
 Аватар для Nick007
101 / 94 / 38
Регистрация: 30.09.2009
Сообщений: 442
22.07.2014, 02:05
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
function get_chaild($data,$parent_id){
    foreach ($data as $key => $value) {
        if($value['id'] !== $parent_id) continue;
            $arr = array(
                'id' =>       $value['id'],
                'name' =>       $value['id'],
                'childrens' => array()
            );
        
//echo '<pre>'.print_r($value,1).'</pre>';
        if( ($value['parent_id'] !== '') ){
            $arr['childrens'] = get_chaild($data,$value['parent_id']);
        }
    }
    return $arr;
}
//id  | parent_id | name
$arr = array(
    array('id'=>0,'parent_id'=>'','name'=>'name0'),
    array('id'=>1,'parent_id'=>'','name'=>'name1'),
    array('id'=>2,'parent_id'=>1,'name'=>'name2'),
    array('id'=>3,'parent_id'=>2,'name'=>'name3'),
);
$arr_res = array();
foreach ($arr as $key => $value) {
    $arr_res[] = get_chaild($arr, $value['id']);
}
echo '<pre>'.print_r($arr_res,1).'</pre>';
Добавлено через 2 минуты
что бы образовать нужную вам структуру,
используйте рекурсивную проверку,
результатом данного кода получите:

Добавлено через 1 минуту
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
Array
(
    [0] => Array
        (
            [id] => 0
            [name] => 0
            [childrens] => Array
                (
                )
 
        )
 
    [1] => Array
        (
            [id] => 1
            [name] => 1
            [childrens] => Array
                (
                )
 
        )
 
    [2] => Array
        (
            [id] => 2
            [name] => 2
            [childrens] => Array
                (
                    [id] => 1
                    [name] => 1
                    [childrens] => Array
                        (
                        )
 
                )
 
        )
 
    [3] => Array
        (
            [id] => 3
            [name] => 3
            [childrens] => Array
                (
                    [id] => 2
                    [name] => 2
                    [childrens] => Array
                        (
                            [id] => 1
                            [name] => 1
                            [childrens] => Array
                                (
                                )
 
                        )
 
                )
 
        )
 
)
0
0 / 0 / 0
Регистрация: 18.07.2011
Сообщений: 13
22.07.2014, 02:42  [ТС]
Спасибо! Только массив должен быть немного другим

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
[
       [1] => [  
                   [id] => 1 
                   [parent_id] => 0 
                   [name] => name0 
                   [childs] => [] 
]
       [2] => [ 
                  [id] => 2 
                  [parent_id] => 0 
                  [name] => name1 
                  [childs] => [ 
                                    [3] => [
                                               [id] => 3 
                                               [parent_id] => 2 
                                               [name] => name2 
                                               [childs] => [ 
                                                                  [4] => [ 
                                                                               [id] => 4
                                                                               [parent_id] => 3
                                                                               [name] => name3
                                                                               [childs] => []
                                                                            ]
                                                                  ]
                                               ]
                   ]
0
 Аватар для Nick007
101 / 94 / 38
Регистрация: 30.09.2009
Сообщений: 442
22.07.2014, 02:55
в приведенном коде я не учитывал, что ключ в массиве должен совпадать с id записи в базе
это легко исправить и приести резкльтат как массив в массиве тоже просто:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
function get_chaild($data,$parent_id){
    foreach ($data as $key => $value) {
        if($value['id'] !== $parent_id) continue;
            $arr = array(
                'id' =>       $value['id'],
                'name' =>       $value['id'],
                'childrens' => array()
            );
        
//echo '<pre>'.print_r($value,1).'</pre>';
        if( ($value['parent_id'] !== '') ){
            $arr['childrens'] = array($value['parent_id']=>get_chaild($data,$value['parent_id']));
        }
    }
    return $arr;
}
//id  | parent_id | name
$arr = array(
    array('id'=>0,'parent_id'=>'','name'=>'name0'),
    array('id'=>1,'parent_id'=>'','name'=>'name1'),
    array('id'=>2,'parent_id'=>1,'name'=>'name2'),
    array('id'=>3,'parent_id'=>2,'name'=>'name3'),
);
$arr_res = array();
foreach ($arr as $key => $value) {
    $arr_res[$value['id']] = get_chaild($arr, $value['id']);
}
echo '<pre>'.print_r($arr_res,1).'</pre>';
Добавлено через 22 секунды
результат:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
Array
(
    [0] => Array
        (
            [id] => 0
            [name] => 0
            [childrens] => Array
                (
                )
 
        )
 
    [1] => Array
        (
            [id] => 1
            [name] => 1
            [childrens] => Array
                (
                )
 
        )
 
    [2] => Array
        (
            [id] => 2
            [name] => 2
            [childrens] => Array
                (
                    [1] => Array
                        (
                            [id] => 1
                            [name] => 1
                            [childrens] => Array
                                (
                                )
 
                        )
 
                )
 
        )
 
    [3] => Array
        (
            [id] => 3
            [name] => 3
            [childrens] => Array
                (
                    [2] => Array
                        (
                            [id] => 2
                            [name] => 2
                            [childrens] => Array
                                (
                                    [1] => Array
                                        (
                                            [id] => 1
                                            [name] => 1
                                            [childrens] => Array
                                                (
                                                )
 
                                        )
 
                                )
 
                        )
 
                )
 
        )
 
)
Добавлено через 2 минуты
вам скрипт по любому придется переделывать,
для оптимизации под выборку данных из базы,
а не подобия выборки в виде массива,
как в данном случае
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.07.2014, 02:55
Помогаю со студенческими работами здесь

Иерархическое дерево категорий
Дано иерархичное дерево категорий. Нужно зделать функцию которая будет выводить дерево в таком виде: Недвижемость -Дома --2х...

Иерархическое дерево. Начало пути
Здравствуйте!!! Я перерыл много учебников и форумов и везде пишут о бинарных деревьях. В них я более менее разобрался, а вот как создать...

Сформировать дерево Т и определить число вхождений параметра Е в дерево Т - Блок схема
Сформировать дерево Т и определить число вхождений параметра Е в дерево Т. Вот решение задачи, народ, помогите, кто может, составить...

Как считать матрицу из файла с произвольным типом элементов и произвольным размером матрицы
У меня есть шаблонный класс Matrix, шаблоном является тип элементов. Как можно считать матрицу элементов шаблонного типа из файла, если мы...

Добавить вложения Access во вложения задачи Outlook
Всем привет. Помогите кто может плиз. Дано: форма Access -- Задачи с полем Вложения (вложения могут...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru