Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/75: Рейтинг темы: голосов - 75, средняя оценка - 4.93
24 / 24 / 11
Регистрация: 28.12.2010
Сообщений: 142

Рекурсивное раскрытие словаря

01.11.2011, 00:11. Показов 15648. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Подскажите как рекурсивно пройтись по примерно такой структуре:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
{"OP1" :
[
    {"OP2" :
    [
        {"U2" : "U1"},
        {"U3" : "U1"}
    ]},
 
    {"OP2" :
    [
        {"U5" : {"U4" : "U1"}},        
        {"U6" : {"U4" : "U1"}}
    ]
    }
]
}
Порядок вложенности может быть любой.
Камнем преткновения является одновременное обращение к списку по индексу и к словарю по ключу.

Как совместить оба типа обращения в одной процедуре?

Уровень моих знаний позволяет применить это:

Python
1
2
3
4
5
6
7
8
9
def Recursive(_item):
    if _item.__class__ == {}.__class__:
        for i in _item:
            print(_item[i])
            Recursive(_item[i])
    if _item.__class__ == [].__class__:
        for i in _item:
            print(i)
            Recursive(i)
Внимание: Данный код является примером того как делать не следует!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2011, 00:11
Ответы с готовыми решениями:

Рекурсивное заполнение и чтение из словаря
Здравствуйте. Мне необходимо заполнить словарь, так, чтобы получилось дерево. Данные представляются буквами английского алфавита и...

Из словаря создается объект, именами атрибутов которого будут ключи словаря
Из словаря создается объект, именами атрибутов которого будут ключи словаря, а значениями - значения из словаря по заданным ключам (a,b,c),...

Как проверить наличие значения словаря словаря в словаре словарей?
есть массив parsdata, который содержит результаты парсинга. нужно проверить, спарсилось ли что-то новое. или нет в сравнении со словарем...

3
224 / 209 / 63
Регистрация: 26.05.2011
Сообщений: 363
01.11.2011, 04:03
Вы бы написали поточнее, что именно Вы хотите получить на выходе.
вот рабочий код Вашей функции:
Python
1
2
3
4
5
6
7
8
9
10
def recursive(obj):
    if isinstance(obj, dict):
        for key, value in obj.iteritems():
            print(key)
            recursive(value)
    elif isinstance(obj, list):
        for item in obj:
            recursive(item)
    else:
        print(obj)
1
24 / 24 / 11
Регистрация: 28.12.2010
Сообщений: 142
01.11.2011, 12:38  [ТС]
Я хотел найти универсальный способ обращения к dict, list, set. Без проверки принадлежности к типу: isinstance или _item.__class__.

А целью является рекурсивный проход по структурам произвольного типа.
0
224 / 209 / 63
Регистрация: 26.05.2011
Сообщений: 363
02.11.2011, 03:32
Цитата Сообщение от PAVEL_USER Посмотреть сообщение
Я хотел найти универсальный способ обращения к dict, list, set. Без проверки принадлежности к типу: isinstance или _item.__class__
Без проверки, ИМХО, не выйдет
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2011, 03:32
Помогаю со студенческими работами здесь

Рекурсивное раскрытие пакета
#include <iostream> template <typename T> void Show(T const & r) { std::cout << r << std::endl; } template <typename...

Рекурсивное создание словаря с типами и размерами файлов
Здравствуйте. Рекурсивно прохожу по директории. В словарь qmap записываю расширение файла, и его размер. если встречаю папку, спускаюсь...

Рекурсивное и не рекурсивное вычисление НОД
Здравствуйте! Имеется код вычисления НОД. Как сделать его рекурсивным и НЕ рекурсивным, и в чём отличие рекурсивного вычисления от...

Как можно сделать сортировку словаря по значениям из другого словаря
Ребят, не подскажите как можно сделать сортировку словаря по значениям из другого словаря? Например, у меня есть некий уже готовый и...

Превратить первый список в набор ключей словаря, а второй список добавить к каждому ключу словаря в виде списка
Даны два списка с одинаковым количеством элементов. Создать новый словарь. Превратить первый список в набор ключей словаря, а второй список...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru