0 / 0 / 2
Регистрация: 06.02.2016
Сообщений: 133

Разложите код по полочкам, пожалуйста

07.07.2016, 12:45. Показов 1327. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот код, взятый с хабра из статьи "Визуализация каталогов на Python средствами NetworkX"

Python
1
2
3
4
5
6
7
8
9
10
11
    def get_tree(tree=[u"E:\\Музыка",], G=nx.Graph(), itr= 0, max_itr=900):
        point = tree.pop( 0)
        itr = itr + 1
        sub_tree = [os.path.join(point, x) for x in os.listdir(point) if os.path.isdir(os.path.join(point, x))]
        if sub_tree:
            tree.extend(sub_tree)
            G.add_edges_from(map(lambda b : (point, b), sub_tree))
        if tree and itr <= max_itr:
            return get_tree(tree, G, itr)
        else:
            return G
def get_tree(tree=[u"E:\\Музыка",], G=nx.Graph(), itr= 0, max_itr=900) - это сама функция построения древа каталогов.
tree - это переменная(или список?), в которую пишется адрес "начала пути" построения. Зачем нужно это "u"?
itr и max_itr - это счётчик и его максимальное значение глубины вложения каталогов, которые мне, в принципе не нужны. Их ведь можно выкинуть без последствий? Разумеется выкинув их и из кода.
point = tree.pop( 0) - некая переменная, в которую записывается "верхний" каталог, правильно?
itr = itr + 1 - ну это понятно - увеличение счётчика
sub_tree = [os.path.join(point, x) for x in os.listdir(point) if os.path.isdir(os.path.join(point, x))] - тут он объединяет верхнюю директорию с последующей вложенной (os.path.join(point, x) for x in os.listdir(point)), если она существует ( if os.path.isdir(os.path.join(point, x)))?
if sub_tree: tree.extend(sub_tree) - если в sub_tree что-то записалось то он "расширяет" основное дерево, дописывая туда "под-дерево"?
G.add_edges_from(map(lambda b : (point, b), sub_tree)) - по логике понятно, что тут добавляются связи между элементами дерева, но что такое map, lambda - я так и не понял. Ну то есть я почитал их описание, но всё равно... можно "на пальцах"?
if tree: - если дерево ещё не пустое
return get_tree(tree, G) - запускаем функцию заново
else: return G - или возвращаем граф
Хех, в итоге сам почти всё разложил. Но на заданные в тексте вопросы нужны ответы.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.07.2016, 12:45
Ответы с готовыми решениями:

Разложите пожалуйста по полочкам код (не могу понять)
$connection = new mysqli($db_hostname, $db_username, $db_password, $db_database); if ($connection-&gt;connect_error)...

Разложите по полочкам ))
Внизу приведена полностью работающая программа и дана задача. Не могли бы вы ясно и четко написать пояснения к каждой строке )) ...

разложите все по полочкам
Здравствуйте! помогите разобраться с прогой: смысл проги в том, что по траектории (восьмерка лежащая) движется фугура (звезда), звезда по...

3
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
07.07.2016, 12:49
Цитата Сообщение от Александр Летов Посмотреть сообщение
но что такое map, lambda - я так и не понял
А это уже основы python, которые стоило бы знать. Гугли, все есть в сети.
0
0 / 0 / 2
Регистрация: 06.02.2016
Сообщений: 133
07.07.2016, 13:03  [ТС]
Цитата Сообщение от alex925 Посмотреть сообщение
Гугли, все есть в сети.
Так я гуглил. Нашёл описания, но до конца так и не понял.

Функция map() позволяет обрабатывать одну или несколько последовательностей с помощью заданной функции:

>>> list1 = [7, 2, 3, 10, 12]
>>> list2 = [-1, 1, -5, 4, 6]
>>> map(lambda x, y: x*y, list1, list2)
[-7, 2, -15, 40, 72]
Как я понял - lambda это функция. В данном случае она переменожает x и y из соответствующих списков, а благодоря map проходятся все элементы списка. Но в моём коде она что делает? Тут ведь никаких действий нет просто (lambda b : (point, b), sub_tree) и откуда взялось b если оно нигде ничему не равно?

И ещё возник вопрос os.listdir(path=".") - список файлов и директорий в папке.. Но. Она не выводит список файлов. Только папок. Почему?
0
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
07.07.2016, 13:08
Лучший ответ Сообщение было отмечено Александр Летов как решение

Решение

Цитата Сообщение от Александр Летов Посмотреть сообщение
Функция map() позволяет обрабатывать одну или несколько последовательностей с помощью заданной функции:
Это, то, для чего она может применяться и применяется в данном случае. Но в целом ее назначение применить какую-то функцию к набору данных (к интерируемому объекту) (список, кортеж и т д). В результате она возвращает генератор с результатом.

Цитата Сообщение от Александр Летов Посмотреть сообщение
Как я понял - lambda это функция.
Да, это анонимная функция

Цитата Сообщение от Александр Летов Посмотреть сообщение
и откуда взялось b если оно нигде ничему не равно?
Это аргумент, который принимает lambda.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.07.2016, 13:08
Помогаю со студенческими работами здесь

Разложите мне программу по полочкам
Помогите разобраться в программе. Я ничего не понимаю в Delphi. Пару раз открывала программу. Как к программе подключается база...

Объясните про внедрение зависимостей в .net core. Разложите все по полочкам
Если сервис зарегистрировать как singleton (AddSingleton). То он будет один для всех пользователей? Если так, то как я понимаю singleton...

Разложите пожалуйста по шагам выражение
Разложите пожалуйста по шагам выражение a-=((b++&gt;&gt;2!=c)+1)|++c

Разложите пожалуйста по шагам выражение a^=b++==3?--c:b---c
Разложите пожалуйста по шагам выражение a^=b++==3?--c:b---c, в какой последовательности считать (приоритеты)

Разложите пожалуйста по шагам выражение a^=b++==3?--c:b---c
Разложите пожалуйста по шагам выражение a^=b++==3?--c:b---c, в какой последовательности считать (приоритеты)


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru